水仙花数是指一个 3 位数以上的数字, 它各位数的 3 次幂相加会等于它本身( 例如:1^3 + 5^3+ 3^3 = 153 )
- 如果要求计算 100-1000 有哪些水仙花数, 该如何实现?
- 首先, 我们得通过循环遍历 100-1000 的每一个数值 (i).
for i in range(100, 1000):
- 然后我们获取数值 i 的各位数
hundred = int((i % 1000 - ten * 10 - one ) / 100) # 百位
ten = int((i % 100 - one) / 10) # 十位数
one = int(i % 10) # 个位
也可以通过操作字符串 str
获取各位数的, 不过呢获取后还需要转换成 int
类型, 因为计算幂次方不支持 str
类型
num = str(i)
hundred = int(num[0]) # 百位数
ten = int(num[1]) # 十位数
one = int(num[2] # 个位数
3.最后我们用 if
来判断 i
的各位数的 3 次幂相加等不等于它本身, 如果等于则输出
if (pow(one, 3) + pow(ten, 3) + pow(hundred, 3)) == i :
print(i)
else:
pass
4.输入结果如下
153
370
371
407