题解 | #完全数计算#

完全数计算

http://www.nowcoder.com/practice/7299c12e6abb437c87ad3e712383ff84

import math
def factorlist(num):
    li1=[]
#     print (num,int(math.sqrt(num))
    tem=int(math.sqrt(num))+1
    for i in range(1,tem):
        if num%i==0:
            li1.append(i)
            li1.append(num//i)
#     print(list(set(li1)))
    return li1
 
while True:
    try:
        n=int(input())
        count = 0
        for j in range(2,n+1):
            m = sum(factorlist(j))-j
            if m == j:
                count += 1
        print(count) 
    except:
        break
全部评论

相关推荐

迟缓的斜杠青年巴比Q了:简历被投过的公司卖出去了,我前两天遇到过更离谱的,打电话来问我有没有意向报班学Java学习,服了,还拿我学校一个学长在他们那报班学了之后干了华为OD当招牌
点赞 评论 收藏
分享
06-02 15:53
阳光学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务