python:找出1~9999之间的所有完美数 完美数是除自身外其他所有因子的和正好等于这个数本身的数

xiaoxiao2021-02-28  19

找出1~9999之间的所有完美数,完美数是除自身外其他所有因子的和正好等于这个数本身的数例如: 6 = 1 + 2 + 3, 28 = 1 + 2 + 4 + 7 + 14

import math def main(): for num in range(1, 10000): sum = 0 for factor in range(1, int(math.sqrt(num)) + 1): if num % factor == 0: sum += factor if factor > 1 and num / factor != factor: sum += num / factor if sum == num: print(num) if __name__ == '__main__': main()
转载请注明原文地址: https://www.6miu.com/read-2626888.html

最新回复(0)