问题描述:如果一个 3 位数等于其各位数字的立方和,则称这个数为水仙花数。#例如:153 = 1^3 + 5^3 + 3^3,因此 153 就是一个水仙花数。
练习1:输入一个3位数,判断是否为水仙花数
方法一:
a = num %10
b =int(((num %100)-a)/10)
c =int((num- a- b*10)/100)
if num == a**3+b**3+c**3:
print("输入的数为水仙花数:")
else:
print("输入的数不是水仙花数")
方法二:
num = int(input('请输入一个三位数:'))
if num == pow(num // 100 , 3) + pow(num % 10 , 3) + pow(num // 10 % 10, 3):
print("这是一个水仙花数%d" % num)
else:
print("这不是一个水仙花数%d" % num)
练习2:打印出100-999内所有的水仙花数
方法一:将数字转化为字符串,通过索引的方法判断
for i in range(100,1000):
s = str(i)
if i == int(s[0])**3+int(s[1])**3+int(s[2])**3:
print("水仙花数为:",i)
方法二:用算数运算获取百位十位个位数字
for i in range(100,1000):
baiwei=i//100
shiwei=i%100//10
gewei=i%10
if i==baiwei**3+shiwei**3+gewei**3:
print("水仙花数为:",i)