每天一習題,提升Python不是問題!!有更簡潔的寫法請評論告知我!
https://www.cnblogs.com/poloyy/category/1676599.html
題目
如果一個正整數等於除它本身之外其他所有除數之和,就稱之為完全數。 例如:6是完全數,* 因為6 = 1+2+3; 下一個完全數是28 = 14+7+4+2+1。 求1000以下的完全數
解題思路
- 外循環6-1000以內的數字
- 內循環當前數字,得到所有整除數,並添加到一個列表
- 列表求和比較當前數字是否一致
答案
all = [] for num in range(6, 1001): lists = [] for n in range(1, num): if num % n == 0: lists.append(n) if sum(lists) == num: all.append(num) print(all)
