题目:水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。 例如:153=1×1×1+5×5×5+3×3×3。本题要求编写程序,计算所有N位水仙花数。
输入格式:输入在一行中给出一个正整数N(3≤N≤5)
输出格式:按递增顺序输出所有N位水仙花数,每个数字占一行
输入样例:
3
输出样例:
153
370
371
407
解答:
import math#利用Python自带的math模块
n=int(input())
for i in range(int(math.pow(10,n-1)),int(math.pow(10,n))):#遍历的范围,n为2时[100,999],这里特别注意range()中必须是int型,但是math.srqt()返回的是float型,所以要进行类型转换
num=i
sum=0
while True:#如果有明显的循环结构,但是结束条件逻辑不好写,就不断循环,中间用break退出循环
digit=num%10
sum=sum+math.pow(digit,n)
num=num//10#通过先%后/的方式【/后为0结束】,可以实现取数字各个位上的数字的过程
if num==0:
break