快速线性筛法求素数

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)的乘积

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值