SY_XLR 2021-09-19 14:16 采纳率: 100%
浏览 510
已结题

素数,现在给出n,要你求是否为素数,是输出Yes,否则输出No

Description
对于大于1的自然数,如果n为素数,那么所有大于1且不大于n的平方根的自然数都不能整除n,反之亦然。所以我们可以通过测试来确定n是否为素数。现在给出n,要你求是否为素数,是输出Yes,否则输出No

每行一个正整数n,n<=2^32-1,如果n为0,则输入结束。判断n是否为素数

每行输出一个用例的结果,如果是输出"Yes",否则输出“No”

Sample Input
2
3
4
5
6
0

Sample Output
Yes
Yes
No
Yes
No

#include<stdio.h>
#include<math.h>
int main()
{
    int i,n;
    int a = 0;
    while(scanf("%d",&n));
    {
        if(n==0)
        {
            return 0;
        }
        else
        {
         for(i=1;i<=sqrt(n);i++)
         {
             if(n%i==0)
             {
                a+=1;
             }
         }
         if(a==1)
         {
          printf("Yes\n"); 
         }
         else
         {
          printf("No\n");
         }
        }
    }    
    return 0;
}

我的是这样,哪里不对?

  • 写回答

3条回答 默认 最新

  • qzjhjxj 2021-09-19 22:09
    关注

    修改如下,问题见注释,共参考:

    #include<stdio.h>
    #include<math.h>
    int main()
    {
        int i,n;
        int a = 0;
        while(scanf("%d",&n)==1)// ';' 修改,这里多了分号
        {
            if(n==0)//n=0 时,退出
            {
                break;
                //return 0;
            }
            else
            {
              a=0;
              for(i=2;i<=sqrt(n);i++) //for(i=1;i<=sqrt(n);i++)
              {
                 if(n%i==0)
                 {
                    a=1;//a+=1;
                    break;
                 }
              }
              if(a==1 || n==1)
              {
                 printf("No\n");
              }
              else
              {
                 printf("Yes\n");
              }
            }
        }
        
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 9月28日
  • 已采纳回答 9月20日
  • 创建了问题 9月19日

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器