Java之递归判断素数

例1 判断一个数是不是素数

法一:判断一个数是不是素数---当数字n除以2~n-1 中的数字的模==0时,说明不是素数

public class Test {
    public static void main(String[] args) {
        //判断一个数是不是素数---当数字n除以2~n-1 中的数字的模==0时,说明不是素数
        int n = 53;
        int i = 2;
        for (; i < n; i++) {
            if (n % i == 0) {
                System.out.println(n+"不是素数!");
                break;
            }
//            }else{
//                System.out.println("n是素数");//这样写就错误,9不是素数
//            }
        }
        if (i == n) {//运行到20行
            System.out.println(n+"是素数!");
        }
    }
}

法二:当n不是素数的时候,比如16=1*16=2*8=4*4,可以发现16是可以看成除开小于等于n/2的数字的,也就是[2,n/2],那么可以认为当数字n除以2~n/2 中的数字的模==0时,说明不是素数

public static void main(String[] args) {
        //判断一个数是不是素数---当数字n除以2~n/2 中的数字的模==0时,说明不是素数
        int n = 10;
        int i = 2;
        for (; i <=n/2; i++) {
            if (n % i == 0) {
                System.out.println(n+"不是素数!");
                break;
            }

        }
        if (i > n/2) {//运行到20行
            System.out.println(n+"是素数");
        }
    }

法三:同样发现16=1*16=2*8=4*4中有一半的因数是小于等于根号16的,那么可以同样认为当数字n除以2~根号n 中的数字的模==0时,说明不是素数

public static void main(String[] args) {
    //判断一个数是不是素数---当数字n除以2~根号n 中的数字的模==0时,说明不是素数
    int n=9;
    int i=2;
    for(;i<=Math.sqrt(n);i++){//注意这个根号n的写法
        if(n%i==0) {
            System.out.println(n + "不是素数!");
            break;
        }
    }
    if(i>Math.sqrt(n)){
        System.out.println(n+"是素数!");
    }
}

例2 判断1-100之间的数是不是素数

public static void main(String[] args) {
    //判断1-100之间的数是不是素数
    for(int n=1;n<101;n++){
        int i=2;
        for(;i<=Math.sqrt(n);i++){
            if(n%i==0) {
                System.out.println(n + "不是素数!");
                break;
            }
        }
        if(i>Math.sqrt(n)){
            System.out.println(n+"是素数!");
        }
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张张_张

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值