代碼題(2)— 統計所有小於非負整數 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;    
        
    }
};

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM