JavaSE习题 用Java解决素数问题
目录
1.判定素数
题目一:判定一个数字是否是素数。(曾经百度面试题)
方法一:
问题分析:a.素数是指除了1和它本身以外,不能被其他正整数整除的数字。
b.所以我们想到2~(它本身-1)之内的数字,都不能被整除这个数。所以可以用依次循环来解决这个问题。
即num%i (i的值为2~(它本身-1)之内的数字)=0,则不是素数。且需要立即结束循环。
如果没有符合上述循环的数字,直到 i 的值等于或大于它本身,循环才可以结束,此时则判定是素数。
所以我们可以得到如下代码:
import java.util.Scanner;
public class TestDome {
public static void main(String[] args) {
Scanner scanner =new Scanner(System.in);
while(scanner.hasNextInt()){
int num =scanner.nextInt();
int i =2;
for(; i < num; i++ ){
if(num % i==0){
System.out.println(num +"不是素数");
break;
}
}
if(i >= num){
System.out.println(num +"是素数");
}
}
}
}
运行结果如下:
方法二:
问题分析:a.我们需要知道一个结论:
!!!一个数(x)的除数或被除数中肯定有一个数字小于等于根号x。
例如:x :16 x=a*b;
1*16 2*8 4*4
b.所以我们想到方法一中 2~(它本身-1)之内的数字,都不能被整除这个数。所以可以用依次循环来解决这个问题。
即num%i (i的值为2~(它本身-1)之内的数字)=0,则不是素数。且需要立即结束循环。
如果没有符合上述循环的数字,直到 i 的值等于或大于它本身,循环才可以结束,此时则判定是素数。
可以替换为:2~根号x 的数字,都不能被整除这个数。所以可以用依次循环来解决这个问题。
即num%i (i的值为2~根号x 的数字)=0,则不是素数。且需要立即结束循环。
如果没有符合上述循环的数字,直到 i 的值大于根号x,循环才可以结束,此时则判定是素数。
c.我们需要了解在Java中如何对数字开根号—则需引用Math.sqrt( );方法。
所以我们可以得到如下代码:
import java.util.Scanner;
public class TestDome {
public static void main(String[] args) {
Scanner scanner =new Scanner(System.in);
while(scanner.hasNextInt()){
int num =scanner.nextInt();
int i =2;
for(; i <= Math.sqrt(num); i++ ){
if(num % i==0){
System.out.println(num +"不是素数");
break;
}
}
if(i > Math.sqrt(num)){
System.out.println(num +"是素数");
}
}
}
}
运行结果如下:
注意事项:我们在面试的时候一定要用方法二!!!
2.打印一定范围之内的所有素数
题目二:打印1~100之间的所有素数。
问题分析:a.我们可以发现此题目与题目一的区别是给定了数字范围,不用你自己输入测试。
所以,编写此题目代码时就不需要以下语句了:
Scanner scanner =new Scanner(System.in);
// while(scanner.hasNextInt()){//可不断输入,否则输入一次程序就运行结束了。
int num =scanner.nextInt();//}
这些语句意思是用户可以自己输入数字进行判断,所以这里不需要。
b.我们发现上面判断素数的时候就需要用到循环,这里需要判断数字1~100,
所以,需要再加上一层循环,直到数字100也被判断完毕后程序结束。
也就是使用二重循环来解决此题。
c.因为此题只需要打印出素数,所以在情况为素数的时候不用打印,直接break结束程序就好。
所以我们可以得到如下代码:
public class TestDome {
public static void main(String[] args) {
for (int j = 1; j <= 100 ;j++) {
int i =2;
for(; i <= Math.sqrt(j); i++ ){
if(j % i==0){
// System.out.println(j +"不是素数");
break;
}
}
if(i > Math.sqrt(j)){
System.out.println(j+"是素数");
}
}
}
}
运行结果如下: