java求 1~n 的素数

   素数就是在2~n-1的数中,能找到一个数能整除n,则n为素数。

所以用两个循环遍历就可以得到素数了,外层循环用来遍历2~n,内层循环用来遍历2~n-1。

但是在内层循环判断素数时,不需要从2~n-1一个一个判断,

因为,一个数化成两个数的乘积的形式时,总会有其中一个数小于等于这个数的开方

例如:16 = 2*8时,存在2小于等于4

           24 = 3*8时,3小于Math.sqrt(24)

           24 = 4*6时,4小于Math.sqrt(24)

所以得到内层for循环

for (int j = 2; j <= Math.sqrt(i); j++)

总体代码为

public class Test {
    public static void main(String[] args) {
        primeNum(888);
    }

    public static void primeNum(int n) {
        //用于输出排版
        int count = 0;

        //从2开始找
        for (int i = 2; i < n; i++) {
            int temp = -1;
            //测试2~i的开方是否有数能被i整除
            for (int j = 2; j <= Math.sqrt(i); j++) {
                //如果有i能被j整除,则此i不为素数,给此时temp为1,标记该数
                if (i % j == 0) {
                    temp = 1;
                    break;
                }
            }
            //没有标记的数就都是素数
            if (temp == -1) {
                System.out.print(i + "\t");
                count++;
                if (count % 5 == 0) {
                    System.out.println();
                }
            }
        }
        System.out.println("\n1~" + n + "的素数一共有" + count +"个");
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值