这道题的循环没看懂为什么选D
求解 有点复杂 运行程序lst=
k=0
for count in range(4):
t=0
while t<3:
k=k%4+1
if lst !=0:
t+=1
lst = 0
print(k)
结果
3
2
4
1
>>>
最后一行是1
答案是D 逃兵 发表于 2021-2-13 15:51
运行程序
这是怎么运算的?为什么是3241这个顺序呀? 这种题什么用没有 for 第一次循环 lst=
while第一次循环 k=1,t=1
二 k=2,t=2
三 k=3,t=3
然后执行list=0 打印3
for 第2次循环lst=
while第一次循环 k=3,t=0
二 k=4,t=1
三 k=1,t=2
四 k=2,t=3
然后执行list=0 打印2
for 第3次循环lst=
while第一次循环 k=2,t=0
二 k=3,t=0
三 k=4,t=1
四 k=1,t=2
五 k=2,t=2
6 k=3,t=2
7 k=4,t=4
然后执行list=0 打印4
for 第4次循环lst=
while循环里k不停的1234其中只有k=1时候才会t+=1
所以最后跳出循环也是k=1
整道题思路就是这样,不知道该有多无聊会出这样的题 我们做题就是透过现象看本质,这题看起来复杂,其实分析一下就会变清晰很多,我只给几个思路,剩下的你自己去算
这道题总体的循环过程关键是 k而 k = k % 4 + 1 k的集合为 k%4 ∈ [ 0 , 3 ]且 k 为整数 那么 k∈ [ 1 , 4 ]
而最终的执行命令就变成了 lst = 0 就是讲[ 0 , 1 , 1 , 1 , 1 ] 变成 [ 0 , 0 , 0 , 0 , 0 ]的过程
而变换的条件 k 取决于 t if lst != 0决定了 无论何时只有lst != 0 时 t 才会发生变化,而无论 t 怎样变化都会
在 t == 3的时候跳出循环
所以最终的问题就变成了 当 t == 3 时k 分别等于几 的问题剩下的只需要在演算纸上,写一个列表,然后数数就好了
不需要数 12 次,只需要数 9 次,因为剩下的最后 那个 lst 中 的 1 的位置,就是 k 的值 qq1151985918 发表于 2021-2-13 16:19
我们做题就是透过现象看本质,这题看起来复杂,其实分析一下就会变清晰很多,我只给几个思路,剩下的你自己 ...
谢谢!
页:
[1]