1. 程式人生 > >代碼題(2)— 統計所有小於非負整數 n 的質數的數量

代碼題(2)— 統計所有小於非負整數 n 的質數的數量

code 整數 color () res size result bool rime

  質數也叫素數,只能被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 的質數的數量