JavaSE习题 用Java解决素数问题

JavaSE习题 用Java解决素数问题

目录

1.判定素数

2.打印一定范围之内的所有素数


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+"是素数");
            }

        }


    }
}



运行结果如下:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值