C程序打印素数到n

时间:2016-06-28 18:04:14

标签: c nested-loops

下面是我写的代码,用于要求用户输入数字n并打印素数直到n。 我得到的输出只有3个。程序不会进入超过3的循环并显示输出为:1 2 3。

#include <stdio.h>
void main()
{
        int a, i, j, flag = 0;
        printf("Enter n?\n");
        scanf("%d",&a);
        printf("Prime no.s till %d are: ",a);
        for(i=1; i<=a; i++)
        {
                for(j=2; j<=i/2; j++)
                {
                        if(i%j==0)
                        {
                                flag=1;
                                break;
                        }
                }
                if(flag==0)
                        printf("%d ",i);
        }
        printf("\n");
}

2 个答案:

答案 0 :(得分:2)

您正在使用flag来判断候选人是否为素数。但是因为你在程序开始时初始化它,一旦找到非素数,每个后续候选者也将被视为非素数。

每次更改flag时,您都需要重新初始化i

答案 1 :(得分:2)

我发现有两个错误,首先1不是素数,所以在2开始循环。

其次,您必须在第一个循环中初始化flag

for(i=2; i<=a; i++)
    {
    flag=0;
    for(j=2; j<=i/2; j++)
    //...

计划会议:

Enter n?
19
Prime no.s till 19 are: 2 3 5 7 11 13 17 19