质数筛法
1. 埃拉托斯特尼筛法
从小到大枚举每一个数
这种筛法可以进行优化,例如枚举到
bitset<N> not_prime;
not_prime[1]=1;
for(int i=2;i*i<=n;i++)
{
if(not_prime[i]==0)
{
for(int j=i*i;j<=n;j+=i)
{
not_prime[j]=1;
}
}
}
For(i,1,n)
{
if(!not_prime[i]) prime[++cnt]=i;
}
2. 欧拉筛
埃氏筛法会将一个合数重复多次标记。如果能让每个合数都只被标记一次,那么时间复杂度就可以降到
考虑让每一个合数只被其最小质因子标记。还是从小到大枚举每一个数
如果不
的话,那么 就会被 标记,而 ,所以 也是 的一个质因数,由于序列 是递增的,所以 ,所以 不是 的最小质因子,违背了每一个合数只被其最小质因子标记的原则,所以需要 。
for(int i=1;i<=n;i++)
{
if(!notprime[i])
{
prime[++cnt]=i;
}
for(int j=1;j<=cnt&&(long long)i*prime[j]<n;j++)
{
notprime[i*prime[j]]=1;
if(i%prime[j]==0)
{
break;
}
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】