const int N = 100000;
int prime[N]={0},num_prime = 0;
int isNotprime[N]={1,1};
void makeprime(){
for(int i=2;i<N;i++){if(isNotprime[i]==0){
prime[num_prime++]=i;
}
for(int j=0;j<num_prime&&i*prime[j]<=N;j++){
isNotprime[i*prime[j]]=1;
if(i%prime[j]==0)break;
}
}
}
代码如上,原理很简单,建议在纸上用笔模拟下大概的过程,肯定就懂了
补充:1)原理:
i. 任何一个合数都可以表示成一个质数和一个数的乘积
ii. 假设A是一个合数,且A = x * y,这里x也是一个合数,那么有:
A = x * y; (假设y质数,x合数)
x = a * b; (假设a是质数,且a < x)
=》 A = a * b * y = a * Z (Z = b * y)
即一个合数(x)与一个质数(y)的乘积可以表示成一个更大的合数(Z)与一个更小的质数(a)的乘积