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
我觉得在本课爱因斯坦的问题小甲鱼老师好像编得有点复杂了,看不明白,求大神指点一下。
每个人的思路不一样而已。
就你的代码而言 代码是少了点,效率跟 小甲鱼版本 差远了。
x = 7 * (i+1) # 根据题意,x一定是7的整数倍,所以每次乘以7
不知道上面红色部份你有没有理解。要不然讲效率也跟你白讲 因为你的是n = n + 1,就是每次把n加1判断是不是符合条件
小甲鱼的是x = 7 * (i + 1),就是乘以7之后判断是否符合条件,所以运算量比你的少。 谢谢大神1们!
页:
[1]