Count Primes
Description:
Count the number of prime numbers less than a non-negative number, n
解题思路:
题意为求小于n的质数的个数。有两种方法:
1、naive办法,对小于n的每个数,检查是否为质数。而检查m是否为质数,需要验证是否都不能被2~pow(m, 0.5)整除。这个方法的时间复杂度为O(n^2),空间复杂度为O(1)。会产生超时错误。
class Solution {
public:
int countPrimes(int n) {
int count=0;
for(int i=0; i<n; i++){
if(isPrim(n)){
count++;
}
}
return count;
}
bool isPrim(int n){
if(n<=1){
return false;
}
double up=pow(n, 0.5);
for(int i=2; i<=up; i++){
if(n%i==0){
return false;
}
}
return true;
}
};2、用一个数组来标记是否为质数。大体思想是:2是质数,那么2的所有倍数(除本身)都不是质数,此时标记2的所有倍数(除本身)为非质数。从小到大扫描,若当前扫描的是质数,则标记其所有的非本身的倍数为非质数。最后对所有质数计数即可。下面为代码:
class Solution {
public:
int countPrimes(int n) {
if(n<2){
return 0;
}
bool primFlag[n];
memset(primFlag, 1, sizeof(bool) * n);
primFlag[0]=primFlag[1]=false;
double up = pow(n, 0.5);
for(int i=2; i<up; i++){
if(primFlag[i]){
for(int j=2; j*i<n; j++){
primFlag[j*i]=false;
}
}
}
int count=0;
for(int i=0; i<n; i++){
if(primFlag[i]){
count++;
}
}
return count;
}
};这个算法的空间复杂度为fO(n),时间复杂度比较复杂。该方法称为Eratosthenes算法。3、算法2的改进。
class Solution {
public:
int countPrimes(int n) {
if(n<2){
return 0;
}
bool primFlag[n];
memset(primFlag, 1, sizeof(bool) * n);
primFlag[0]=primFlag[1]=false;
double up = pow(n, 0.5);
int count=n-2;
for(int i=2; i<up; i++){
if(primFlag[i]){
for(int j=2; j*i<n; j++){
if(primFlag[j*i]){
primFlag[j*i]=false;
count--;
}
}
}
}
return count;
}
};原文:http://blog.csdn.net/kangrydotnet/article/details/45341053