微信公众号:龙跃十二
我是小玉,一个平平无奇的小天才!持续更新,欢迎关注!
用心分享,共同成长
没有什么比你每天进步一点点更实在了
本文已经收录至我的GitHub,欢迎大家踊跃star🌟。
GitHub
水仙花:
先来说说什么是水仙花?
例如:153=1100+510+3*1
且153=13+53+33
三次方是根据这个数字的位数来决定的。
这种形式的数字就被称为水仙花数。(要求水仙花数必须是三位以上的整数哦!)
今天小玉跟大家讲讲如何用python来实现1000以内的水仙花数的数量统计。
编码思路:
- 在输入一个任意的数字i的时候,首先需要判断这个数字为几位数,也就是要输出一个位数n
- 分解这个数的各个位的数字。
- 判断每个位上的数字的n次方之和是否为i。
代码实现:
# 水仙花数:
i = 100 #水仙花数必须是三位及以上的整数
num = 0 #num用来累计数鲜花数的个数,初始值设置为0
while i < 1000: #执行while循环
a = (i // 100) #a、b、c分别为这个三位数的百位、十位、个位
b = ((i-a*100) // 10)
c = (i - 100*a - 10*b)
if i == a ** 3 + b ** 3 + c ** 3: #用if语句判断是否满足水仙花数的规则
print("水仙花数是:",i) #输出每一个水仙花数
num += 1 #每输出一次,水仙花数的个数就累计+1
i +=1 #实现100到1000的叠加
print(f"10000以内的水仙花有{num}个。") #输出所有的水仙户个数
运行结果:
水仙花数的运行结果对你有帮助吗?有帮助就关注一下小玉吧~
我知道你一定会给我点赞的😊
网友评论