#include<bits/stdc++.h>
using namespace std;
bool isPrime[100000005];//1 表示是素数
int Prime[100000005],cnt=0;//存质数
void GetPrime(int x)
{
memset(isPrime,1,sizeof(isPrime));
isPrime[1]=0;//1不是素数
for(int i=2;i<=x;i++)
{
if(isPrime[i])
{
Prime[++cnt]=i;//纪录素数, 这个prime[0] 相当于 cnt,用来计数
}
for(int j=1;j<=cnt&&i*Prime[j]<=x;j++)
//从Prime[1],即最小质数2开始,逐个枚举已知的质数,并期望Prime[j]是(i*Prime[j])的最小质因数
//当然,i肯定比Prime[j]大,因为Prime[j]是在i之前得出的
{
isPrime[i*Prime[j]]=0;
if(i%Prime[j]==0)
break;
}
}
}
int main()
{
int n,q;
cin>>n>>q;
GetPrime(n);
while(q--)
{
int k;
cin>>k;
cout<<Prime[k]<<endl;
}
}
欧拉筛模板(线性筛素数)
最新推荐文章于 2024-08-02 11:25:27 发布