题解 | #完全数计算#

完全数计算

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

#这个输入140000以内的可以成功,再大就容易超时了,想不到改进的办法了
import math
def check(num):
    a=1
    for i in range(2,int(math.sqrt(num))+1):
        if num%i==0:
            a+=i+num//i
        if a>num:
            return False
    if a==num:
        return True
    return False
n=int(input())
if n==1:
    print(1)
count=0
for i in range(2,n+1):
    if check(i):
        count+=1
print(count)

全部评论

相关推荐

06-26 15:33
青岛工学院 Java
积极的秋田犬要冲国企:他现在邀请我明天面试
点赞 评论 收藏
分享
05-19 19:57
蚌埠学院 Python
2237:Gpa70不算高,建议只写排名,个人技能不在多而在精,缩到8条以内。项目留一个含金量高的,减少间距弄到一页,硕士简历也就一页,本科不要写很多
实习,投递多份简历没人回...
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

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