Java期末复习(一)
Text1
程序功能:
求给定正整数m以内的素数之和。
思路解析:
1.素数(Prime Number)又称质数,在数学中,是指大于1的自然数,除了1和它本身外,不能被其他自然数整除。例如,2、3、5、7等都是素数。
2.判断一个数是否为素数的方法有很多,这里给出一种常见的方法:遍历法
从2开始,将这个数与2到它平方根之间的所有整数相除,如果有能整除的,则这个数不是素数,遍历结束如果没有找到能整除的,则是素数。
public class Main {
static int fun(int m)
{
int sum = 0;
for (int i = 2; i <= m; i++) {
if (isPrime(i)) {
sum += i;
}
}
return sum;
}
static boolean isPrime(int n) {
if (n <= 1) {
return false;
}
for (int i = 2; i <= Math.sqrt(n); i++) {
if (n % i == 0) {
return false;
}
}
return true;
}
public static void main(String[] args) {
int y;
y=fun(20);
System.out.println("y="+y);
}
}
Text2
程序功能:
编程通过键盘输入年份year,并显示输出是否是闰年。
思路解析:
闰年是指公历年份中,能被4整除但不能被100整除,或者能被400整除的年份。
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int year = scanner.nextInt();
if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) {
System.out.println(year + "是闰年。");
} else {
System.out.println(year + "不是闰年。");
}
}
}
Text3
程序功能:
随机生成0到20之间的一个整数,计算并输出它的阶乘值。
思路解析:
我们要计算一个整数的阶乘。阶乘是一个整数乘积的循环,从1乘到该整数本身。我们可以使用一个循环来迭代乘积,从1乘到n。在每次迭代中,我们将乘积存储在变量f中,以便在循环结束后我们可以得到阶乘的结果。
public class Main {
public static void main(String[] args) {
int n=(int)(Math.random()*21); //构造20以内的一个整数
int f=1;
for (int i = 1; i <= n; i++) {
f *= i;
}
System.out.println(n+"!= "+f); //输出阶乘的结果f
}
}
Text4
程序功能:
打印出所有的 "水仙花数 ",所谓 "水仙花数 "是指一个三位数,其各位数字立方和等于该数本身。
思路解析:
我们要计算一个三位数的每个数字的立方和。首先将数字拆分为个、十、百位,然后分别计算每个数字的立方和,最后将它们相加得到总和。
例如,对于数字 123,它会先计算个位数的立方(13=1),然后计算十位数的立方(23=8),最后计算百位数的立方(3^3=27),最后将它们相加得到总和 1+8+27=36。
while (num > 0) {
int b = num % 10;
sum += Math.pow(b, 3);
num /= 10;
}
这段代码的执行过程如下:
- 首先,将原始数字 num 赋值给变量 sum,以便在循环结束后得到总和。
- 使用 while 循环,当 num 大于 0 时,继续执行以下操作:
- 将 num 取模 10,得到当前数字的最后一位数字 b。
- 将b 的立方加到变量 sum 中。
- 将 num 整除 10,以便进入下一轮循环。
- 循环结束后,变量 sum 包含了原始数字每个数字的立方和。
public class Main {
public static void main(String[] args) {
for (int i = 100; i < 1000; i++) {
int sum = 0;
int num = i;
while (num > 0) {
int b = num % 10;
sum += Math.pow(b, 3);
num /= 10;
}
if (sum == i) {
System.out.println(i);
}
}
}
}