1、机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。按照如下规则计算机票价格: 旺季(5-10月) 头等舱9折,经济舱8.5折,淡季(11月到来年4月)头等舱折,经济舱6.5折。
import java.util.Scanner;
public class FlightPriceCalculator {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
// 输入机票原价、月份和头等舱或经济舱
System.out.print("请输入机票原价:");
double price = scanner.nextDouble();
System.out.print("请输入月份(1-12):");
int month = scanner.nextInt();
System.out.print("请输入舱位类型(头等舱/经济舱):");
String cabinClass = scanner.next();
// 根据月份和舱位类型计算机票价格
double discount; // 折扣
if (month >= 5 && month <= 10) { // 旺季头等舱9折,经济舱8.5折
if (cabinClass.equals("头等舱")) {
discount = 0.9;
} else {
discount = 0.85;
}
} else { // 淡季头等舱8折,经济舱6.5折
if (cabinClass.equals("头等舱")) {
discount = 0.8;
} else {
discount = 0.65;
}
}
double finalPrice = price * discount; // 计算最终价格
System.out.println("机票最终价格为:" + finalPrice);
}
}
将方法抽取之后:
import java.util.Scanner;
public class FlightPriceCalculator {
// 计算机票价格
public static double calculateFlightPrice(double price, int month, String cabinClass) {
double discount; // 折扣
if (month >= 5 && month <= 10) { // 旺季头等舱9折,经济舱8.5折
if (cabinClass.equals("头等舱")) {
discount = 0.9;
} else {
discount = 0.85;
}
} else { // 淡季头等舱8折,经济舱6.5折
if (cabinClass.equals("头等舱")) {
discount = 0.8;
} else {
discount = 0.65;
}
}
return price * discount; // 返回最终价格
}
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
// 输入机票原价、月份和头等舱或经济舱
System.out.print("请输入机票原价:");
double price = scanner.nextDouble();
System.out.print("请输入月份(1-12):");
int month = scanner.nextInt();
System.out.print("请输入舱位类型(头等舱/经济舱):");
String cabinClass = scanner.next();
// 调用计算机票价格的方法
double finalPrice = calculateFlightPrice(price, month, cabinClass);
System.out.println("机票最终价格为:" + finalPrice);
}
}
2、判断 101-200 之间有多少个素数,并输出所有素数。
public class PrimeNumberCounter {
public static void main(String[] args) {
int count = 0; // 计数器,记录素数个数
// 判断 101-200 之间的每个数字是否为素数
for (int i = 101; i <= 200; i++) {
boolean isPrime = true; // 标记当前数字是否是素数
// 判断当前数字是否为素数
for (int j = 2; j < i; j++) {
if (i % j == 0) { // 若能整除,则不是素数
isPrime = false;
break;
}
}
if (isPrime) { // 若是素数,则输出并计数器加一
System.out.print(i + "\t");
count++;
if (count % 10 == 0) { // 每输出 10 个素数换一行
System.out.println();
}
}
}
System.out.println("\n101-200 之间共有 " + count + " 个素数。");
}
}
以上代码中,我们使用了两重循环来实现判断数字是否是素数的功能。首先,外层循环遍历 101-200 之间的每个数字;内层循环从 2 到该数字的前一个数,判断该数字能否被整除。如果能被整除,则该数字不是素数。只要找到一个因子,就可以判定当前数字不是素数,并跳出内层循环。如果一直到循环结束都没有找到因子,那么当前数字就是素数,将其输出,并计数器加一。同时,我们每输出 10 个素数就换一行,方便观察。经过遍历之后,我们得到了 101-200 之间的所有素数,并统计了素数的个数,最后输出给用户。