编程求出1000以内的所有完数——python

完数:一个数如果恰好等于它的因子之和,这个数就是完数,如6=1+2+3.

整体思路

  1. 首先找出任意一个数的所有因子【因子就是所有可以整除这个数的数,不包括自身】
def wan_num(n):
    for i in range(1, n):
        if n % i == 0:
            yield i
  1. 将所有因子相加,看是否等于这个数
n = 1000
result = {}
for i in range(1, 1000):
    L = wan_num(i)
    L1 = list(L)
    if i == sum(L1):
        print("this is OK")
        result[i] = L1
  1. 输出结果
print(result)
{496: [1, 2, 4, 8, 16, 31, 62, 124, 248], 28: [1, 2, 4, 7, 14], 6: [1, 2, 3]}
  1. 总结:程序写的low了点,以后抽空改进哇,实在没时间处理了!另外也没有严格检查结果是否正确,大家自己琢磨修改去吧。
  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值