鱼C论坛

 找回密码
 立即注册
查看: 3144|回复: 5

[已解决]爱因斯坦阶梯的问题

[复制链接]
发表于 2017-9-17 17:02:31 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 pokerLH 于 2017-9-17 21:51 编辑

33.png 3.png

为什么一定要有  x = 7 * (i + 1)这个,把i给他了,那这个x到哪儿去了?也没输出出去啊,那有什么用啊?为啥也不能删除啊?
最佳答案
2017-9-17 18:43:36
x初始化为7(阶梯为7的倍数),在循环内如果满足 x%2==1 and .......这一串,说明这时的x就是我们要找的答案。

不满足if的判断条件, x增加1倍(阶梯数为7的倍数)。如果最终答案不止一个,后边的x的值会覆盖开始的x(你这个程序循环必须全部找完)。  可以考虑用列表存放x的值。

如果最终答案只有一个,建议在flag=1之后,加一句break。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2017-9-17 17:40:07 | 显示全部楼层
不是if else吗
如果if的条件,就用x=7,然后按照里面的算
但是如果if不行,x留着也就没有用了
所以赋值给其他
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-9-17 18:43:36 | 显示全部楼层    本楼为最佳答案   
x初始化为7(阶梯为7的倍数),在循环内如果满足 x%2==1 and .......这一串,说明这时的x就是我们要找的答案。

不满足if的判断条件, x增加1倍(阶梯数为7的倍数)。如果最终答案不止一个,后边的x的值会覆盖开始的x(你这个程序循环必须全部找完)。  可以考虑用列表存放x的值。

如果最终答案只有一个,建议在flag=1之后,加一句break。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-9-17 18:55:38 | 显示全部楼层
请仔细看完后面的注释

  1. x = 7
  2. flag = 0

  3. while x <= 1000: #1000内的阶梯数
  4.     if (x%2 == 1) and (x%3 == 2) and (x%5 == 4) and (x%6==5):
  5.         flag=1
  6.         print('阶梯数是:', x)
  7.     x += 7 # 根据题意,x一定是7的整数倍

  8. if flag == 0:
  9.     print('在程序限定的范围内找不到答案!')

  10. '''
  11. 科学家爱因斯坦做过这样的问题:

  12. 一条长长的阶梯,如果你每步跨2阶,那么最后余1阶;如果每步跨3阶,那么最后剩下2阶;如果每步跨5阶,最后剩4阶;如果每步跨6阶,最后剩5阶;只有当你每步跨7阶时,才正好走完,一阶也不剩。问这条阶梯最少有多少阶?

  13. 解:这个题目换一种说法,就是:

  14. 一条长阶梯,它的阶数被2除余1,被3除余2,被5除余4,被6除余5,被7能整除,求至少有多少阶?

  15. 这样,把题目压缩简化了,可以方便思考。题中共有5个条件,可以分两步解决。

  16. 第一步,根据“阶数被2除余1,被3除余2,被5除余4,被6除余5”这四个条件

  17. 第二步,第五个条件是“能够被7整除”(x一定是7的整数倍)
  18. '''
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-9-17 21:36:17 | 显示全部楼层
本帖最后由 gunjang 于 2017-9-17 21:41 编辑

人脑优化。。。
x除以2,3,5,6分别余1 2 4 5,那么x+1正好是2 3 5 6的倍数
所以x+1肯定是上述的最小公倍数30的倍数
第一个x是29
  1. x = 29
  2. while True:
  3.         if x%7 == 0:
  4.                 print(x)
  5.         x += 30
  6.         if x > 5000:
  7.                 break
复制代码

119
329
539
749
959
step=210
或者就一句
  1. print([x for x in range(1,5000) if (x%7==0) and (x%2==1) and (x%3==2) and (x%5==4) and (x%6==5)])
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-9-17 21:52:19 | 显示全部楼层
谢谢各位~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-2 12:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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