猫不理 发表于 2017-12-23 16:29:52

py005课爱因斯坦的问题

小甲鱼版本
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('在程序限定的范围内找不到答案!')

我的版本
n=1
while n>0:
    if n%2==1 and n%3==2 and n%5==4 and n%6==5 and n%7==0:
      print(n)
      n=0
    else:
      n=n+1

我觉得在本课爱因斯坦的问题小甲鱼老师好像编得有点复杂了,看不明白,求大神指点一下。

ba21 发表于 2017-12-23 17:07:40

每个人的思路不一样而已。
就你的代码而言 代码是少了点,效率跟 小甲鱼版本 差远了。
x = 7 * (i+1) # 根据题意,x一定是7的整数倍,所以每次乘以7
不知道上面红色部份你有没有理解。要不然讲效率也跟你白讲

py大神 发表于 2017-12-23 17:47:40

因为你的是n = n + 1,就是每次把n加1判断是不是符合条件
小甲鱼的是x = 7 * (i + 1),就是乘以7之后判断是否符合条件,所以运算量比你的少。

洛灵 发表于 2017-12-24 10:42:01

谢谢大神1们!
页: [1]
查看完整版本: py005课爱因斯坦的问题