问题描述
153是一个非常特殊的数,它等于它的每位数字的立方和,即153=111+555+333。编程求所有满足这种条件的三位十进制数。
输出格式
按从小到大的顺序输出满足条件的三位十进制数,每个数占一行。
参考代码
# 方法一:
for i in range(100, 1000):
a = str(i)
if (int(a[0])**3 + int(a[1])**3 + int(a[2])**3) == i:
print(i)
# 方法二:
for i in range(100, 1000):
if (i // 100) ** 3 + (i // 10 % 10) ** 3 + (i % 10) ** 3 == i:
print(i)
考察知识点
1.因为要判断每位数字的立方和,所以需要提取各位数字。因为是三位十进制数,可以考虑传统的:整除100提取百位,整除10再对10取余提取十位,对10取余提取个位;也可以使用字符串索引的方法。
2.python中有三种除法
1>传统除法:1/2=0;1.0/2.0=0.5
2>精确除法:
from __future__ import division
print(1/2)
# 输出0.5
3>地板除法:不管操作数为何种类型,总会舍去小数部分,返回数字序列中比真正的商小的最接近的数字
print(876//100)
print(876/100)
# 输出
8
8.76