输出100000以内的质数的个数:2021-07-10

这篇博客探讨了计算100000以内质数的两种优化方法。首先,未经优化的算法通过两层循环检查每个数字的因数,时间消耗较大。然后进行了第一次优化,将内部循环限制到 sqrt(i),显著减少了计算时间。最后,通过进一步优化,完全避免了不必要的遍历,再次提高了效率。优化后的算法在处理大数据时体现出时间复杂度的优势。
摘要由CSDN通过智能技术生成

输出100000以内的质数的个数:

一、无优化前
boolean isFlag = true;//标识i是否被除尽
int count=0;
long start=System.currentTimeMillis();//获取当前时间的毫秒数
for (int i = 2; i <= 100000; i++) {
for (int j = 2; j <=i; j++) {
if (i % j == 0) {
isFlag = false;//被除尽不是质数
}

          }
          if (isFlag == true) {//如果是质数就输出

// System.out.print(i+" ");
count++;
}
isFlag=true;
}
long end=System.currentTimeMillis();//获取结束当前时间
System.out.println(“质数的个数:”+count);
System.out.print(“所花费的时间为:”+(end-start));
在这里插入图片描述
二、优化一:
public class PrimeNumber {
public static void main(String[] args) {
boolean isFlag = true;//标识i是否被除尽
int count=0;
long start=System.currentTimeMillis();//获取当前时间的毫秒数
for (int i = 2; i <= 100000; i++) {
for (int j = 2; j < i; j++) {
// for (int j = 2; j <= Math.sqrt(i); j++) {
if (i % j == 0) {
isFlag = false;//标记被除尽不是质数
break;
}

          }
          if (isFlag == true) {//如果是质数就输出

// System.out.print(i+" ");
count++;
}
isFlag=true;
}
long end=System.currentTimeMillis();//获取结束当前时间
System.out.println(“质数的个数:”+count);
System.out.print(“所花费的时间为:”+(end-start));
}在这里插入图片描述
三、二次优化:
boolean isFlag = true;//标识i是否被除尽
int count=0;
long start=System.currentTimeMillis();//获取当前时间的毫秒数
for (int i = 2; i <= 100000; i++) {
// for (int j = 2; j < i; j++) {
for (int j = 2; j <= Math.sqrt(i); j++) {
if (i % j == 0) {
isFlag = false;//标记被除尽不是质数
break;
}

          }
          if (isFlag == true) {//如果是质数就输出

// System.out.print(i+" ");
count++;
}
isFlag=true;
}
long end=System.currentTimeMillis();//获取结束当前时间
System.out.println(“质数的个数:”+count);
System.out.print(“所花费的时间为:”+(end-start));在这里插入图片描述
当数据越大,对于时间的比较越明显,一个好的算法和处理问题的机制,能帮我们时间的复杂度问题。

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值