【牛客网 - 华为机试 - HJ56 完全数计算】

描述

完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数。

它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身。

例如:28,它有约数1、2、4、7、14、28,除去它本身28外,其余5个数相加,1+2+4+7+14=28。

输入n,请输出n以内(含n)完全数的个数。

数据范围:

输入描述:

输入一个数字n

输出描述:

输出不超过n的完全数的个数

思路:

step1:输入一个数字,同时创建一个空列表,便于存放查询到的完全数;

step2:除去1,从2-n开始进行遍历;设置一个计数器便于求和;对于因数,因为是成对存在的,我们只需要从1开始,遍历到它的平方根即可,剩下部分可以用除法来找到;

step3:计数器求得的结果如果是该数的二倍,则将其添加至列表中;

step4:打印列表长度

代码如下:

n = int(input())
c = []
for i in range(2,n+1):
    p = 0
    for j in range(1,int(i**0.5)+1):
        if i%j == 0:
            p = p + j
            p = p + i/j
    if 2*i == p:
        c.append(i) 
print(len(c))

题解 | #完全数计算#_牛客博客

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不错就是对

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值