|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
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('在程序限定的范围内找不到答案!')
第六节这个能有大神把每步的作用讲解一下吗?有点不能理解
谢谢!
看注释吧:
- x = 7 # 由题意得知,一定被 7 整除,所以一定是 7 的倍数,初始化开始阶梯等于 7 省去无用计算
- i = 1 # 这是记录循环次数
- flag = 0
- while i <= 100: # 设置循环 100 次内寻找爱因斯坦阶梯
- if (x%2 == 1) and (x%3 == 2) and (x%5 == 4) and (x%6==5): # 由题意可知,阶梯数要同时满足被 2、3、5、6 求余后余数为 1、2、4、5
- flag = 1 # 若符合条件则找到阶梯,设置 flag = 1 是为了表示在循环中找到了阶梯
- else:
- x = 7 * (i+1) # 根据题意,阶梯数一定是 7 的整数倍,所以每次以 7 增长阶梯数
- i += 1 # 记录循环次数
- if flag == 1: # 若 flag 为 1 说明找到阶梯了,打印最后一次找到的阶梯数
- print('阶梯数是:', x)
- else: # 反之 flag 不为 1 说明没有找到阶梯
- print('在程序限定的范围内找不到答案!')
复制代码
实际上甲鱼哥代码麻烦了些,可以简化成这样:
- x = 7
- for i in range(100):
- if (x%2 == 1) and (x%3 == 2) and (x%5 == 4) and (x%6==5):
- print('阶梯数是:', x)
- break # 这里如果只打印一次可以直接退出循环,如果全部打印可以去掉 break
-
- x = 7 * (i+1)
复制代码
|
|