悠悠岁月 发表于 2021-1-28 17:34:48

while y :的含义,循环不是不能结束吗。具体看下面代码

def gcd(x, y):
    while y:
      t = x % y
      x = y
      y = t

    return x
   
print(gcd(4, 6))
没看懂这个循环,循环怎么运行的

青出于蓝 发表于 2021-1-28 17:35:50

本帖最后由 青出于蓝 于 2021-1-28 17:36 编辑

while y=如果y为真(True)
任何非零、或非空(null)的值均为true。

青出于蓝 发表于 2021-1-28 17:37:40

也就是说如果y为真就一直循环。
不懂得话欢迎继续追问~

jackz007 发表于 2021-1-28 17:39:42

本帖最后由 jackz007 于 2021-1-28 17:42 编辑

      让 x % y 的余数成为新 y,旧 y 成为新 x,继续求 x % y,直到余数为 0 为止,这个时候的 y 就是最大公约数。

Peteryo01223 发表于 2021-1-28 17:44:32

本帖最后由 Peteryo01223 于 2021-1-28 17:46 编辑

我加了注释,如下:
def gcd(x, y): # 定义一个叫做 gcd 的函数,里面有两个变量,分别是 x 和 y
   while y: # 只要 y 为真,或者说只要 y 不是零,就进行循环
         t = x % y # t 被赋值为 x 除以 y 的余数,这是 % 在 python 中的定义,即:求余数
         x = y # 现在把 y 的值 赋值给 x
         y = t # 现在,再把 刚才的余数 t 的值 赋值给 y。这么一操作,就循环起来了,做一次除法,就换一下值,继续做同样的除法,循环进行下去。

   return x
   
print(gcd(4, 6)) # 现在 打印出这个函数的值,赋值 x 和 y 分别为 4 和 6
页: [1]
查看完整版本: while y :的含义,循环不是不能结束吗。具体看下面代码