题解 | #完全数计算#

完全数计算

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

if __name__ == "__main__":
    while True:
        try:
            n = int(input().strip())
            counter = 0
            for i in range(1,n+1):
                pf = 0
                j = 1
                while True:
                    if i%j == 0:
                        divisor = i/j  # 记录较大的约数divisor
                        # 若divisor<=约数j,则表示i已经没有其他约数,减少不必要循环
                        if divisor <= j: 
                            break
                        pf += j + divisor
                    j += 1
                if pf == 2*i:  # 因为循环中当约数为1时,把i本身也加进pf里,所以pf = 2*i。
                    counter += 1
            print(counter)
        except:
            break
全部评论

相关推荐

07-07 14:30
复旦大学 Java
遇到这种人我也不知道说啥了
无能的丈夫:但我觉得这个hr语气没什么问题啊(没有恶意
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
今天 12:02
ssob上原来真有BOSS啊
硫蛋蛋:这种也是打工的,只不是是给写字楼房东打工
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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