【任务】:给定一个正整数N,求出[2,N]中的所有素数。
【说明】:数组valid[i]记录i是否为素数,初始所有的valid[i]都为true,从二开始从小到大枚举i,若valid[i]=true,则把从i^2开始的每一个i的倍数的valid赋为false,结束之后valid[i]=true的就是素数。数组ans用来储存素数。
解法1:依旧1表示素数,0表示合数,先找出一个素数,然后将其与接下来的数相乘,并把它们的乘积置为0
#include<iostream>
#include<cstring>
#define maxn 1000000
using namespace std;
bool valid[maxn];
int ans[maxn];
int main()
{
int n,tot=0;
cin>>n;
memset(valid,true,sizeof(valid));
for(int i=2;i<=n;i++)
{
if(valid[i])
{
tot++;
ans[tot]=i;
}
for(int j=1;((j<=tot)&&(i*ans[j]<=n));j++)
{
valid[i*ans[j]]=0;
if(i%ans[j]==0)
break;
}
}
for(int i=1;i<=tot;i++)
{
cout<<ans[i]<<' ';
}
cout<<endl;
return 0;
}
解法2:
思路:1表示素数,0表示合数,找出一个素数a,并把在[2,n]范围内的a的倍数全部置为0,最后,
剩下的为1的素数则为素数。
#include<iostream>
#define maxn 1000000
using namespace std;
bool valid[maxn];
int ans[maxn];
int main()
{
int n,tot=0;
cin>>n;
for(int i=2;i<=n;i++)
valid[i]=1;
for(int i=2;i<=n;i++)
{
if(valid[i]==1)
{
if(n/i<i)
break;
for(int j=i*i;j<=n;j+=i)
valid[j]=0;
}
}
for(int i=2;i<=n;i++)
{
if(valid[i])
ans[++tot]=i;
}
for(int i=1;i<=tot;i++)
cout<<ans[i]<<' ';
cout<<endl;
return 0;
}