问题描述
153是一个非常特殊的数,它等于它的每位数字的立方和,即153=1*1*1+5*5*5+3*3*3。编程求所有满足这种条件的三位十进制数。
输出格式
按从小到大的顺序输出满足条件的三位十进制数,每个数占一行。
思路:
遍历每一个三位数,对于每一个三位数,取出各个位置上的数字(使用取余),如果其立方和与这个数字相等,则输出
废话不说,上代码!
# 定义一个判断函数,判断这个数字各个位数的立方和是否等于它本身
def isyes(num:int):
a=num
b=[]
while a>0:
b.append(a%10)
a//=10
sum=b[0]**3+b[1]**3+b[2]**3
if sum==num:
return True
else:
return False
# 开始
for i in range(100,1000):
if isyes(i):
print(i)
遍历穷举,永远的神!
答案为
153
370
371
407