m0_67612991 2022-03-22 21:35 采纳率: 57.1%
浏览 886
已结题

判断一个给定的正整数是否是素数

输入格式:输入在第一行给出一个正整数N,随后N行,每行给出一个小于2的31次方的需要判断的正整数,如果是素数,则在一行中输出Yes,否则输出No
提示部分正确,是没有考虑偶数和最大素数的问题吗?改如何体现这一点呢

img

img

  • 写回答

1条回答 默认 最新

  • 木易荆岑 2022-03-22 21:46
    关注

    漏掉了1既不是质数也不是合数

    import math
    n=int(input())
    for i in range(n):
        m=int(input())
        if m==1:
            print('No')
        else:
            for j in range(3, int(math.sqrt(m) + 1),2):
                if m % j == 0 or m % 2 == 0:
                    print('NO')
                    break
                else:
                    print('Yes')
                    break
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 3月31日
  • 已采纳回答 3月23日
  • 创建了问题 3月22日

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!