小弟写了一个用筛法求n以内的所有素数的程序,但是结果总是多了几个数,请各位帮忙看一下:
#include <stdio.h>
#define n 30
int main()
{
int i,j,k,s,a[n],b[n];
j=2;
for(i=0;i<n&&a[i]!=0;i++)//对数组进行初始化
{
if(j<=n)
{
a[i]=j;
j++;
}
else
{
a[i]=0;
j++;
}
b[i]=0;
}
for(i=0;a[i]!=0;i++)
{
for(j=i+1;a[j]!=0;j++)//把所有以a[i]为因子的数清零
{
if(a[j]%a[i]==0)
a[j]=0;
}
for(k=0,j=0;k<n;k++)//把不为零的数赋给数组b[]
{
if(a[k]!=0)
{
b[j]=a[k];
j++;
}
}
for(j=0;j<n;j++)//把数组b[]的值赋给a[]
a[j]=b[j];
}
printf("%d以内的所有素数有%d个分别是:\n",n,i);
for(i=0;a[i]!=0;i++)
printf("%4d",a[i]);
printf("\n");
return 0;
}