素数筛选、标记、素数判断
从小于自己的数字中暴力搜索因数
单次查询的时间复杂度为O(n)
根据 n=a*b,不需要暴搜全部小于自己的数字
只搜索 小于√n 的数字即可
单次查询的时间复杂度为O(√n)
略
预处理时间复杂度 O (N ln ln N)
单次查询时间复杂度O(1)
如果要证明一个数字是合数,只需要证明它是某个质数的倍数即可;因此只需要用质数更新后续判断即可;剪掉了合数更新的部分。
bool vis[N];
inline void sss(int n){
memset(vis,true,sizeof(vis));
for(int i=2;i<=n;i++)
if(vis[i]){
for(int k=2;k*i<=n;k++)
vis[k*i]=false;
}
return ;
}
进一步减少重复情况
每个合数只需要被它最小的那个质因子更新过一次就好了
bool vis[N];int pp[N],tot;
inline void prim(int n){
memset(vis,true,sizeof(vis));
for(int i=2;i<=n;i++){
if(vis[i]) pp[++tot]=i;
for(int j=1;j<=tot&&pp[j]*i<=n;j++){
vis[pp[j]*i]=false;
if(i%prim[j]==0) break;
}
}
return ;
}
速度块,基于概率事件的素数筛,所以有出错率。