筛法的思想是去除要求范围内所有的合数,剩下的就是素数了,而任何合数都可以表示为素数的乘积,因此如果已知一个数为素数,则它的倍数都为合数。
- #include"cstdio"
- #include"cstring"
- using namespace std;
- #define MAX 100000//求MAX范围内的素数
- long long su[MAX],cnt;
- bool isprime[MAX];
- void prime()
- {
- cnt=1;
- memset(isprime,1,sizeof(isprime));//初始化认为所有数都为素数
- isprime[0]=isprime[1]=0;//0和1不是素数
- for(long long i=2;i<=MAX;i++)
- {
- if(isprime[i])
- su[cnt++]=i;//保存素数i
- for(long long j=1;j<cnt&&su[j]*i<MAX;j++)
- {
- isprime[su[j]*i]=0;//筛掉小于等于i的素数和i的积构成的合数
- }
- }
- }
- int main()
- {
- prime();
- for(long long i=1;i<cnt;i++)
- printf("%d ",su[i]);
- return 0;
- }