7-12 两个数的简单计算器
分数 10
作者 沈睿
单位 浙江大学
本题要求编写一个简单计算器程序,可根据输入的运算符,对2个整数进行加、减、乘、除或求余运算。题目保证输入和输出均不超过整型范围。

输入格式:
输入在一行中依次输入操作数1、运算符、操作数2,其间以1个空格分隔。操作数的数据类型为整型,且保证除法和求余的分母非零。

输出格式:
当运算符为+、-、*、/、%时,在一行输出相应的运算结果。若输入是非法符号(即除了加、减、乘、除和求余五种运算符以外的其他符号)则输出ERROR。

输入样例1
-7 / 2
输出样例1
-3
输入样例2
3 & 6
输出样例2
ERROR



import java.util.Scanner;

public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);

String input = scanner.nextLine();
scanner.close();

String[] parts = input.split(" ");

if(parts.length !=3){
System.out.println("ERROR");
return;
}

int num1 = 0;
int num2 = 0;
String operator = parts[1];

try{
num1 = Integer.parseInt(parts[0]);
num2 = Integer.parseInt(parts[2]);
}catch(NumberFormatException e){
System.out.println("ERROR");
}
switch(operator){
case "+":
System.out.println(num1 + num2);
break;
case "-":
System.out.println(num1 - num2);
break;
case "*":
System.out.println(num1 * num2);
break;
case "/":
if(num2 == 0){
System.out.println("ERROR");
}else{
System.out.println(num1 / num2);
}break;
case "%":
if(num2 == 0){
System.out.println("ERROR");
}else{
System.out.println(num1%num2);
}
break;
default:
System.out.println("ERROR");
break;
}
}

}

7-13 日K蜡烛图
分数 15
作者 陈建海
单位 浙江大学
股票价格涨跌趋势,常用蜡烛图技术中的K线图来表示,分为按日的日K线、按周的周K线、按月的月K线等。以日K线为例,每天股票价格从开盘到收盘走完一天,对应一根蜡烛小图,要表示四个价格:开盘价格Open(早上刚刚开始开盘买卖成交的第1笔价格)、收盘价格Close(下午收盘时最后一笔成交的价格)、中间的最高价High和最低价Low。

如果Close<Open,表示为“BW-Solid”(即“实心蓝白蜡烛”);如果Close>Open,表示为“R-Hollow”(即“空心红蜡烛”);如果Open等于Close,则为“R-Cross”(即“十字红蜡烛”)。如果Low比Open和Close低,称为“Lower Shadow”(即“有下影线”),如果High比Open和Close高,称为“Upper Shadow”(即“有上影线”)。请编程序,根据给定的四个价格组合,判断当日的蜡烛是一根什么样的蜡烛。

输入格式:
输入在一行中给出4个正实数,分别对应Open、High、Low、Close,其间以空格分隔。

输出格式:
在一行中输出日K蜡烛的类型。如果有上、下影线,则在类型后加上with 影线类型。如果两种影线都有,则输出with Lower Shadow and Upper Shadow。

输入样例1
5.110 5.250 5.100 5.105
输出样例1
BW-Solid with Lower Shadow and Upper Shadow
输入样例2
5.110 5.110 5.110 5.110
输出样例2
R-Cross
输入样例3
5.110 5.125 5.112 5.126
输出样例3
R-Hollow

import java.util.Scanner;

public class Main {

public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);

// 读取输入数据
String line = scanner.nextLine();
String[] prices = line.split(" ");

// 将输入的字符串转换为浮点数
double open = Double.parseDouble(prices[0]);
double high = Double.parseDouble(prices[1]);
double low = Double.parseDouble(prices[2]);
double close = Double.parseDouble(prices[3]);

// 判断蜡烛的基本类型
String candleType;
if (close < open) {
candleType = "BW-Solid";
} else if (close > open) {
candleType = "R-Hollow";
} else {
candleType = "R-Cross";
}

// 检查影线的存在
boolean hasLowerShadow = low < Math.min(open, close);
boolean hasUpperShadow = high > Math.max(open, close);

// 生成输出结果
StringBuilder result = new StringBuilder(candleType);
if (hasLowerShadow && hasUpperShadow) {
result.append(" with Lower Shadow and Upper Shadow");
} else if (hasLowerShadow) {
result.append(" with Lower Shadow");
} else if (hasUpperShadow) {
result.append(" with Upper Shadow");
}

// 输出结果
System.out.println(result.toString());

scanner.close();
}
}
7-14 求整数段和
分数 15
作者 杨起帆
单位 浙大城市学院
给定两个整数A和B,输出从A到B的所有整数以及这些数的和。

输入格式:
输入在一行中给出2个整数A和B,其中−100≤A≤B≤100,其间以空格分隔。

输出格式:
首先顺序输出从A到B的所有整数,每5个数字占一行,每个数字占5个字符宽度,向右对齐。最后在一行中按Sum = X的格式输出全部数字的和X。

输入样例:
-3 8
输出样例:
-3 -2 -1 0 1
2 3 4 5 6
7 8
Sum = 30



import java.util.Scanner;

public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int A = scanner.nextInt();
int B = scanner.nextInt();
scanner.close();

int sum = 0;
for(int i = A; i <= B; i++){
sum+=i;
}

int count = 0;
for(int i = A; i <= B; i++){
if(count !=0 && count%5 == 0){
System.out.println();
}
System.out.printf("%5d",i);
count++;
}
System.out.println();
System.out.println("Sum = " + sum);
}
}

7-15 计算圆周率
分数 15
作者 杨起帆
单位 浙大城市学院
根据下面关系式,求圆周率的值,直到最后一项的值小于给定阈值。

2
π

=1+
3
1

+
3×5
2!

+
3×5×7
3!

+⋯+
3×5×7×⋯×(2n+1)
n!

+⋯

输入格式:
输入在一行中给出小于1的阈值。

输出格式:
在一行中输出满足阈值条件的近似圆周率,输出到小数点后6位。

输入样例:
0.01
输出样例:
3.132157

import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in=new Scanner(System.in);
double t= in.nextDouble();
double sum=1.0;
double pi=1.0;
int i=1;
while(pi>t){
pi=pi*i/(2*i+1);
sum +=pi;
i++;
}
System.out.printf("%.6f",sum*2);//这里一定要进行格式化,java不要仅仅局限于print和println的输出方式
}
}