鱼C论坛

 找回密码
 立即注册
查看: 2398|回复: 3

[已解决]编写自定义函数(求最大公约数)

[复制链接]
发表于 2017-12-2 17:30:43 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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

    return x
   
这个公式的运行原理是什么?   下面是我自己代入的数字解析,但是发现怎么都不对。

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

    return x

假设x=4,6=y,那最后的输出结果应该是4(这里4%6我在Python运行,返回的结果是4),但是实际上它的输出结果是2,是正确的

我有两个不明白的地方:

1、while后面的y等于6的话,那这个程序不是循环6次吗?
2、这个函数是怎么运行的










最佳答案
2017-12-2 18:13:15
while y:

y ==0 为假, y==非0 为值 。你代入了数字,while循环还没有为0,还没有结果,继续循环啊。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-12-2 18:13:15 | 显示全部楼层    本楼为最佳答案   
while y:

y ==0 为假, y==非0 为值 。你代入了数字,while循环还没有为0,还没有结果,继续循环啊。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-12-2 18:16:40 | 显示全部楼层
ba21 发表于 2017-12-2 18:13
while y:

y ==0 为假, y==非0 为值 。你代入了数字,while循环还没有为0,还没有结果,继续循环啊。

y==0不应该为真吗?  能说的再具体点吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-12-2 18:19:05 | 显示全部楼层
jzh 发表于 2017-12-2 18:16
y==0不应该为真吗?  能说的再具体点吗?

想起来了。。0为假,其他为真,谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-28 07:24

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表