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

Posted eilearn

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了代码题— 统计所有小于非负整数 n 的质数的数量相关的知识,希望对你有一定的参考价值。

   质数也叫素数,只能被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;    
        
    }
};

 

以上是关于代码题— 统计所有小于非负整数 n 的质数的数量的主要内容,如果未能解决你的问题,请参考以下文章

204. 计数质数

LeetCode. 计数质数

204. 计数质数

204计数质数

Leetcode——计数质数

leetcode 简单 第五十八题 计数质数