鱼C论坛

 找回密码
 立即注册
查看: 1136|回复: 1

[已解决]打印10以内的质数,以下代码为什么9还是素数呢?

[复制链接]
发表于 2021-12-25 16:47:46 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
打印10以内的质数,以下代码为什么9还是素数呢?
for i in range(1,10):
     for j in range(2,i+1):
          if i % j == 0 and i > 2:
               print(i, "=", j, "*", i//j)
               break
          else:
               print(i,"是一个素数。")
               break

运行结果:
2 是一个素数。
3 是一个素数。
4 = 2 * 2
5 是一个素数。
6 = 2 * 3
7 是一个素数。
8 = 2 * 4
9 是一个素数。
>>>
最佳答案
2021-12-25 17:05:11
本帖最后由 jackz007 于 2021-12-25 17:59 编辑

        当 i = 9 , j = 2 的时候,由于 9 % 2 != 0 ,就直接判定 9 是素数了。
        问题出在素数判定的逻辑
          if i % j == 0 and i > 2:
               print(i, "=", j, "*", i//j)
               break
          else:
               print(i,"是一个素数。")
               break
        这个逻辑是错误的,否定 i 是素数很容易,只要存在任何一个 j 让 i % j == 0 就可以,但是,确定 i 是素数只测试一个 j 是远远不够的,必须要在测试完所有的 j 之后,也就是说,不可以在内层循环之内,必须是在内层循环结束之后才能最后下结论。
for i in range(1 , 10):
     if i > 1 :
         for j in range(2 , i) :
             if i % j == 0 :
                 print(i , "=" , j , "*" , i // j)
                 break
         else:
             print(i , "是一个素数。")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-12-25 17:05:11 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2021-12-25 17:59 编辑

        当 i = 9 , j = 2 的时候,由于 9 % 2 != 0 ,就直接判定 9 是素数了。
        问题出在素数判定的逻辑
          if i % j == 0 and i > 2:
               print(i, "=", j, "*", i//j)
               break
          else:
               print(i,"是一个素数。")
               break
        这个逻辑是错误的,否定 i 是素数很容易,只要存在任何一个 j 让 i % j == 0 就可以,但是,确定 i 是素数只测试一个 j 是远远不够的,必须要在测试完所有的 j 之后,也就是说,不可以在内层循环之内,必须是在内层循环结束之后才能最后下结论。
for i in range(1 , 10):
     if i > 1 :
         for j in range(2 , i) :
             if i % j == 0 :
                 print(i , "=" , j , "*" , i // j)
                 break
         else:
             print(i , "是一个素数。")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-12 12:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表