筛选法寻找素数——学习笔记

给定数字N,要求找到小于N的所有素数的个数。

我们需要对小于N的每个数x进行判断,判断是否为素数。

我们可以在[2,x-1]之间找x的因素,也可以在[2,sqrt(x)]之间找,当然平方根内查找速度更快。

 

我来介绍一种更快的方法——筛选法。时间复杂度O(Nlog(logN))。

筛选法原理在于:

1.先建立一个长度为N的数组(数组下标正好对应[0,N-1]),先假设每一个数都可能是素数

2.然后从2开始(0,1均不是素数)往后找,每当找到一个素数y时,就把y所有倍数ky(k=2,3,4,,,,(ky<N))找出来排除掉

3.由于素数的倍数都排除掉了(非素数除了0,1以外均由素数因子构成),最后剩下的就是素数了

 

看代码:

//返回值N以内素数的个数
int Prime(int N){
     //建立长度为N的数组,初始值为false
     bool* prime=(bool*)calloc(N,sizeof(bool));
     int count=0;
     
     for(int i=2;i<N;i++){
          //非素数,continue
          if(prime[i]){
               continue;
          }
          
          //打印素数
          printf("The %d prime:%d\n",++count,i);
 
          //排除素数的倍数
          for(int j=i+i;j<N;j+=i){
               prime[j]=true;
          }
     }  
  
     //释放内存,返回
     free(prime);
     return count;
}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值