204. Count Primes

1.描述

Description:

Count the number of prime numbers less than a non-negative number, n.

2.分析

3.代碼

int countPrimes(int n) {
    if (n <= 1) return 0;
    bool *isPrime = (bool*)malloc(n * sizeof(bool));
    for (unsigned int i = 0 ; i < n; ++i)
        isPrime[i] = true;
    int root = sqrt(n);
    for (unsigned int i = 2; i <= root; ++i) {
        if (isPrime[i]) {
            for (unsigned int j = i * i; j < n; j += i) {
                isPrime[j] = false;
            }
        }
    }
    int sum = 0;
    for (unsigned int i = 2; i < n; ++i) {
        if (isPrime[i]) ++sum;
    }
    free(isPrime);
    isPrime = NULL;
    return sum;
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容