鱼C论坛

 找回密码
 立即注册
查看: 1698|回复: 2

[已解决]找出10000以内的**完美数**

[复制链接]
发表于 2020-5-4 17:50:19 | 显示全部楼层
这种写法的原因是因为第三行的range(1, int(num**0.5) + 1),其实也可以使用range(1,10000)#(后面代码也需要相应做出一些改变),这不过考虑到计算机的执行效率来说,前者更快。#(后者要等很长很长的时间)
用前者解的话,就需要注意因子并非仅仅存在于factor in (1, int(num**0.5) + 1)这个范围内,同时num / factor 所得到的数也有可能是因子,因此有了第7行的 result += num // factor。第六行的判断语句num // factor != factor是防止将因子重新加一次的情况出现。
最后还要说一下,这个代码运行后存在1,但是1不是完数,所以,这个东西我的解决方案是把第一段代码改为for num in range(2, 10000).望采纳。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-9 03:00

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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