shaojianjian 发表于 2021-2-13 15:26:28

这道题的循环没看懂为什么选D

求解

洋洋痒 发表于 2021-2-13 15:48:00

有点复杂

逃兵 发表于 2021-2-13 15:51:08

运行程序
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

shaojianjian 发表于 2021-2-13 16:00:35

逃兵 发表于 2021-2-13 15:51
运行程序




这是怎么运算的?为什么是3241这个顺序呀?

永恒的蓝色梦想 发表于 2021-2-13 16:01:26

这种题什么用没有

洋洋痒 发表于 2021-2-13 16:13:02

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


整道题思路就是这样,不知道该有多无聊会出这样的题

qq1151985918 发表于 2021-2-13 16:19:51

我们做题就是透过现象看本质,这题看起来复杂,其实分析一下就会变清晰很多,我只给几个思路,剩下的你自己去算
这道题总体的循环过程关键是 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 的值

shaojianjian 发表于 2021-2-13 16:24:20

qq1151985918 发表于 2021-2-13 16:19
我们做题就是透过现象看本质,这题看起来复杂,其实分析一下就会变清晰很多,我只给几个思路,剩下的你自己 ...

谢谢!
页: [1]
查看完整版本: 这道题的循环没看懂为什么选D