方法一 穷举
按照定义,从2到n-1判断有没有能整除n的数。如果有,则不是素数,否则,是素数
bool is_prime(int n){
if (n < 2){
return false;
}
int i;
for (i = 2; i < n; i++){
if (n%i == 0){
return false;
}
}
return true;
}
算法复杂度:O(n)
方法二 建议使用这种
还是按照定义,不过是从2一直算到sqrt(n),这样算法复杂度降低了很多
bool is_prime(int n){
if (n < 2){
return false;
}
int i;
for (i = 2; i*i <= n; i++){
if (n%i == 0){
return false;
}
}
return true;
}
时间复杂度O(sqrt(n))
方法三:
上面几种方法都只能判断一个数是不是素数,当需要判断1-n里面有多少素数时,就会很麻烦,有一种较为简单的方法就是Eratosthenes筛法
如果一个数是素数,那么这个数的倍数一定不是素数,就是这个思想,把所有的非素数都去掉
bool flag[N];
void fun(){
long long i, j;
for (i = 0; i < N; i++){
flag[i] = true;
}
flag[0] = flag[1] = false;
for (i = 2; i < N; i++){
if (!flag[i]) continue;
for (j = ii; j < N; j += i){
flag[j] = false;
}
}
}
算法复杂度O(nlog log n)
但是这个算法有一个冗余的地方:比如合数10,在枚举2的时候我们判定了一次,在枚举5的时候我们又判定了一次。因此使得其时间复杂度比O(n)要高。