第006讲:Python之常用操作符 - 动动手2. 爱因斯坦的难题
爱因斯坦曾出过这样一道有趣的数学题:有一个长阶梯,若每步上2阶,最后剩1阶;若每步上3阶,最后剩2阶;若每步上5阶,最后剩4阶;若每步上6阶,最后剩5阶;只有每步上7阶,最后刚好一阶也不剩。(小甲鱼温馨提示:步子太大真的容易扯着蛋~~~)
题目:请编程求解该阶梯至少有多少阶?
i = 1
x = 0
a = 0
while i <=1000:
if (i % 2 == 1) and (i % 3 == 2) and (i % 5 ==4) and (i % 6 ==5) and (i % 7 == 0):
x = 1
a = i
i += 1
if x == 1:
print('阶梯数是:',a)
else:
print('在程序限定的范围内找不到答案!')
不知这样写有没有病语? 有什么地方要修改和注意 1,标点符号变成中文的了
2,代码有点啰嗦,给你改了下
i = 1
x = 1
while i <=1000:
if (i % 2 == 1) and (i % 3 == 2) and (i % 5 ==4) and (i % 6 ==5) and (i % 7 == 0):
print('阶梯数是:', i)
break
else:
i += 1
else:
print('在程序限定的范围内找不到答案!') 本帖最后由 sunrise085 于 2020-5-20 10:49 编辑
问题不大,错误有一处,if 后面的 print 内 逗号写成中文的逗号了。
另外,你的程序输出的不是范围内的第一个符合要求的阶梯数,而是最后一个。
若把所有符合要求的都输出
i , x = 1 , 1
while i <=1000:
if (i % 2 == 1) and (i % 3 == 2) and (i % 5 ==4) and (i % 6 ==5) and (i % 7 == 0):
print('阶梯数是:', i)
x = 0
i += 1
if x:
print('在程序限定的范围内找不到答案!')
若只输出第一个
i = 1
while i <=1000:
if (i % 2 == 1) and (i % 3 == 2) and (i % 5 ==4) and (i % 6 ==5) and (i % 7 == 0):
print('阶梯数是:', i)
break
i += 1
else:
print('在程序限定的范围内找不到答案!') 本帖最后由 Twilight6 于 2020-5-20 10:57 编辑
你搜索的范围是 小于 1000 了,而小甲鱼的是小于 100
你的代码是直接找出最后一个最大的阶梯数(在1000范围内最大阶梯数:959)
而且代码中有个中文的逗号要改成英文的
我在你代码上稍微改动了下代码,打印出所有的阶梯了:
i = 1
x = 0
a = ''
while i <=1000:
if (i % 2 == 1) and (i % 3 == 2) and (i % 5 ==4) and (i % 6 ==5) and (i % 7 == 0):
x = 1
a += str(i) + ' '
i += 1
if x == 1:
print('阶梯数是:',a)
else:
print('在程序限定的范围内找不到答案!') qiuyouzhi 发表于 2020-5-20 10:28
1,标点符号变成中文的了
2,代码有点啰嗦,给你改了下
主要是还未学到break() ,不知如何写强退 kedel1 发表于 2020-5-20 11:25
主要是还未学到break() ,不知如何写强退
没事,慢慢学吧,而且break不是函数,是语句,不要有括号。
设个最佳呗~ x = 1 没什么用吧{:5_94:} 禾马 发表于 2020-5-20 15:48
x = 1 没什么用吧
开始时,是作为判断查找的范围里是否有答案的 kedel1 发表于 2020-5-21 09:12
开始时,是作为判断查找的范围里是否有答案的
我没有说明白。在最佳答案代码中我觉得没有意义,也不需要特别用它来判断范围吧{:5_109:} 禾马 发表于 2020-5-21 10:03
我没有说明白。在最佳答案代码中我觉得没有意义,也不需要特别用它来判断范围吧
那应该如何优化? kedel1 发表于 2020-5-22 08:42
那应该如何优化?
我觉得不需要定义X {:7_136:}
页:
[1]