鱼C论坛

 找回密码
 立即注册
查看: 1446|回复: 12

[已解决]第十七课求余数的作业,求助求助

[复制链接]
发表于 2019-6-23 16:20:54 | 显示全部楼层 |阅读模式

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

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

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

    return x
   
print(gcd(4, 6))
这是怎么求出的来的,琢磨了半小时了原理实在搞不懂结果的2是怎样出来的,有大神可以告诉我原理吗??
最佳答案
2019-6-23 16:29:10
x=4,y=6
while y:成立
t= 4
x= 6
y = 4
while y:成立
t= 2
x=4
y=2
while y:成立
t=0
x=2
y=0
while y:不成立
reutrn 2
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-6-23 16:29:10 | 显示全部楼层    本楼为最佳答案   
x=4,y=6
while y:成立
t= 4
x= 6
y = 4
while y:成立
t= 2
x=4
y=2
while y:成立
t=0
x=2
y=0
while y:不成立
reutrn 2
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-6-23 16:29:45 | 显示全部楼层
4除以6不是没有余数吗。。。。6除以4才有余数吧
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-23 16:30:13 | 显示全部楼层
如果是说算法的原理,参见“辗转相除法” https://baike.baidu.com/item/%E8 ... /4625352?fr=aladdin
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-23 16:30:32 | 显示全部楼层
辗转相除法,详情可搜索,
就拿你的gcd(4,6)来说, 我写一下程序运行过程
第一步: y不为0,4%6等于4
第二步:除数给x,余数给y,此时y依旧不为0,6%4等于2
第三步:x=4, y = 2,此时4%2等于0
第四步:x=2, y = 0,退出循环
第五步:打印找出的最大公约数
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-23 16:31:12 | 显示全部楼层
冬雪雪冬 发表于 2019-6-23 16:30
如果是说算法的原理,参见“辗转相除法” https://baike.baidu.com/item/%E8%BE%97%E8%BD%AC%E7%9B%B8%E9%9 ...

好快,我正在写都
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-23 16:32:02 | 显示全部楼层
不从心 发表于 2019-6-23 16:29
4除以6不是没有余数吗。。。。6除以4才有余数吧

小于除数的求余都等于它本身
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-6-23 16:40:26 | 显示全部楼层
冬雪雪冬 发表于 2019-6-23 16:29
x=4,y=6
while y:成立
t= 4

哇,,谢谢谢谢,懂了懂了。但是前面没有这么写:while y != 0:   这一步是可以省略的吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-6-23 16:41:23 | 显示全部楼层
newu 发表于 2019-6-23 16:30
辗转相除法,详情可搜索,
就拿你的gcd(4,6)来说, 我写一下程序运行过程
第一步: y不为0,4%6等于4

感谢鱼油,你们真TM脑子转的快,懂了懂了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-6-23 16:41:53 | 显示全部楼层
newu 发表于 2019-6-23 16:31
好快,我正在写都

恩恩,回复了两个答案了 谢谢  懂了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-23 16:45:19 | 显示全部楼层
不从心 发表于 2019-6-23 16:40
哇,,谢谢谢谢,懂了懂了。但是前面没有这么写:while y != 0:   这一步是可以省略的吗?

while y != 0:即当y不等于0时成立
while y:则是python的特性,0,空字符串,空列表等为False,其余为True,所以可以判断是否为0
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-6-23 16:47:39 | 显示全部楼层
冬雪雪冬 发表于 2019-6-23 16:45
while y != 0:即当y不等于0时成立
while y:则是python的特性,0,空字符串,空列表等为False,其余为Tru ...

哇偶,知道了,感谢大神
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-6-23 16:48:35 | 显示全部楼层
冬雪雪冬 发表于 2019-6-23 16:30
如果是说算法的原理,参见“辗转相除法” https://baike.baidu.com/item/%E8%BE%97%E8%BD%AC%E7%9B%B8%E9%9 ...

恩恩,懂了,我还问了数学老师,小学数学没学好
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-17 02:58

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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