小弟写了一个用筛法求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;
}



 
											





 
	    

 
	


 您的问题不止那个...
您的问题不止那个...

