鱼C论坛

 找回密码
 立即注册
查看: 1280|回复: 3

[已解决]怎么打印100-1000之间的水仙花数?

[复制链接]
发表于 2020-6-16 23:56:16 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
编写一个程序,求 100~999 之间的所有水仙花数。
如果一个 3 位数等于其各位数字的立方和,则称这个数为水仙花数。例如:153 = 1^3 + 5^3 + 3^3,因此 153 就是一个水仙花数。

for i in range(100, 1000):
    sum = 0
    temp = i
    while temp:
        sum = sum + (temp%10) ** 3
        temp //= 10         
    if sum == i:
        print(i)

这段代码看不懂,有大神解释下嘛?
最佳答案
2020-6-17 00:36:57
temp%10   第一次取个为数 ** 3 累加到sum
temp //= 10      重新赋值,去掉个位数

在循环体内,一直循环到temp为0,此时temp值为False。退出循环,继续下一个 i
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-6-17 00:36:57 | 显示全部楼层    本楼为最佳答案   
temp%10   第一次取个为数 ** 3 累加到sum
temp //= 10      重新赋值,去掉个位数

在循环体内,一直循环到temp为0,此时temp值为False。退出循环,继续下一个 i
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-6-17 08:11:32 | 显示全部楼层


解析写在注释里了,按照循环顺序来解读哈

这里拿当循环到 153 时候举例子,这样比较好理解~

for i in range(100, 1000):  # 找100~999的水仙花数

    sum = 0  # 初始化数值,用于后面计算 百十个位数各自3次方的总和

    temp = i  # 找个临时变量来暂时赋值,用于记录本身的值,因为后面计算会改变原本的值

    while temp:
        # 将temp 作为循环条件
        # 假设第1次循环temp = 153
        # 则第2次循环temp = 15
        # 第3次temp=1
        # 第4次因temp=0退出循环

        sum = sum + (temp % 10) ** 3
        # 第1次循环sum = 0+(153%10)**3,sum=27
        # 第2次循环sum = 27+(15%10)**3,sum=152
        # 第3次循环sum = 152+(1)**3 = 153

        temp //= 10
        # temp//10 = 15,则第1次循环temp = 15
        # 第2次循环temp//10=1 ,temp=1
        # 第3次temp//10 = 0 则temp=0

    if sum == i:  # 退出循环后判断是否与本身相等, 若是打印,不是则开启下一次for循环

        print("100-999之间的水仙花数有:", end="")  # print 默认参数end ='\n' 换行符号 我们用end="" 覆盖他的默认值 就不会换行
        print(i)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2020-6-17 08:14:12 | 显示全部楼层
Twilight6 发表于 2020-6-17 08:11
解析写在注释里了,按照循环顺序来解读哈

这里拿当循环到 153 时候举例子,这样比较好理解~

你的回答是最好的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-20 16:33

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表