首页 > 其他 > 详细

代码题(2)— 统计所有小于非负整数 n 的质数的数量

时间:2018-06-18 23:11:50      阅读:557      评论:0      收藏:0      [点我收藏+]

   质数也叫素数,只能被1和它本身整除的。

  利用筛选法。

class Solution {
public:
    int countPrimes(int n) {
        if(n < 3)
            return 0;
        int result = 0;
        vector<bool> isPrime(n+5);
        for(int i=0;i<isPrime.size();++i)
            isPrime[i] = true;
        isPrime[0] = false;
        isPrime[1] = false;
        for(int i=2;i<n;++i)
        {
            if(isPrime[i])
            {
                result++;
                for(int j=i*2;j<n;j+=i)  # 去除i的倍数
                    isPrime[j] = false;
            }
        }
        return result;    
        
    }
};

 

代码题(2)— 统计所有小于非负整数 n 的质数的数量

原文:https://www.cnblogs.com/eilearn/p/9196635.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!