`
uag
  • 浏览: 19332 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
最近访客 更多访客>>
社区版块
存档分类
最新评论

素数筛选法的比较

阅读更多
来求出小于等于n的所有的素数。
    num = 0;
    for(i=2; i<=n; i++)
    {  for(j=2; j<=sqrt(i); j++)
         if( j%i==0 ) break;
       if( j>sqrt(i) ) prime[num++] = i;  //这个prime[]是int型,跟下面讲的不同。
    }
    这就是最一般的求解n以内素数的算法。

素数筛法是这样的:
    1.开一个大的bool型数组prime[],大小就是n+1就可以了.先把所有的下标为奇数的标为true,下标为偶数的标为false.
    2.然后:
      for( i=3; i<=sqrt(n); i+=2 )
      {   if(prime)
          for( j=i+i; j<=n; j+=i ) prime[j]=false;
      }
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics