鱼C论坛

 找回密码
 立即注册
查看: 1194|回复: 6

[已解决]课后题疑问/(ㄒoㄒ)/~~

[复制链接]
发表于 2020-4-4 22:15:26 | 显示全部楼层 |阅读模式

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

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

x
2. 爱因斯坦的难题
爱因斯坦曾出过这样一道有趣的数学题:有一个长阶梯,若每步上2阶,最后剩1阶;若每步上3阶,最后剩2阶;若每步上5阶,最后剩4阶;若每步上6阶,最后剩5阶;只有每步上7阶,最后刚好一阶也不剩。
(小甲鱼温馨提示:步子太大真的容易扯着蛋~~~)
题目:请编程求解该阶梯至少有多少阶?


小甲鱼的答案如下,我几乎看不懂……为什么要设一个flag呢?
x = 7
i = 1
flag = 0

while i <= 100:
    if (x%2 == 1) and (x%3 == 2) and (x%5 == 4) and (x%6==5):
        flag = 1
    else:
        x = 7 * (i+1) # 根据题意,x一定是7的整数倍,所以每次乘以7
    i += 1

if flag == 1:
    print('阶梯数是:', x)
else:
    print('在程序限定的范围内找不到答案!')


以及
我写的代码错在哪里了呢……(心虚得很哈哈

a=1
while not (a%7==0) and (a%6==5) and (a%5==4) and (a%3==2) and (a%2==1):
    a=a+1
print(a)
最佳答案
2020-4-4 22:35:53
你的错误是逻辑运算符优先级搞错了,not的优先级要比and高。
所以你需要把not后面的一长串括起来
flag就是个标记,你随意设定。
完全可以设置成初始值flag="a",符合条件了flag="b",结束while循环后,用if判断一下flag=="b"就知道找没找到了。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-29 09:03

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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