关闭

素数输出优化

标签: 优化素数
183人阅读 评论(0) 收藏 举报
使用素数筛法是这样的:
    1.开一个大的bool型数组prime[],大小就是n+1就可以了.先把所有的下标为奇数的标为true,下标为偶数的标为false.
    2.然后:
      for( i=3; i<=sqrt(n); i+=2 )
{   

           if(prime[i]){

           for( j=i+i; j<=n; j+=i ) prime[j]=false;

           }

      }
    3.最后输出bool数组中的值为true的单元的下标,就是所求的n以内的素数了。
     原理很简单,就是当i是质(素)数的时候,i的所有的倍数必然是合数。如果i已经被判断不是质数了,那么再找到i后面的质数来把这个质数的倍数筛掉。
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:24462次
    • 积分:912
    • 等级:
    • 排名:千里之外
    • 原创:64篇
    • 转载:35篇
    • 译文:0篇
    • 评论:2条
    最新评论