题目内容:
水仙花数是指一个n位数 (n≥3),它的每个位上的数字的n次幂之和等于它本身。
例如:153是一个“水仙花数”,因为 153 是个 3位数,而13+53+3**3==153。
输入一个正整数max,输出100到max之间的所有水仙花数(包括max)。
输入格式:
共一行,为一个正整数。
输出格式:
若干行,从小到大输出水仙花数,一行为一个数。
输入样例:
2500
输出样例:
153
370
371
407
1634
My answer
思路:了解水仙数的含义后,用for在[100,max]中间遍历寻找符合条件的数,难点在怎么把个位,十位数,百位数,千位数取出来,这时我们可以把数字变成字符串。计算n次幂,可以用pow(x,n)函数,当然x**n也行
max = input()
for i in range(100, int(max)+1):
n = len(str(i))
s = 0
for j in str(i):
s += int(j) ** n
if s == i:
print(s)