鱼C论坛

 找回密码
 立即注册
查看: 2395|回复: 2

[已解决]作业欧几里得算法的问题

[复制链接]
发表于 2020-11-27 10:51:23 | 显示全部楼层 |阅读模式

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

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

x
偶然遇到
问题如下
  1. def gcd(a, b):
  2.     while a != 0:
  3.          a,b = b%a,a
  4.     return b
复制代码

代码如上,这样公约数返回1
  1. def gcd(a, b):
  2.     while a != 0:
  3.         a = b % a
  4.         b  = a

  5.     return b
复制代码

这样写公约数返回0
求解释。
这两个写法不都是变量值互换吗?
最佳答案
2020-11-27 11:25:42
这两个写法 是不一样的,第一个写法相当于:
  1. t = a
  2. a = b%a
  3. b = t
复制代码

是把原来a的值给b,而你第二个写法里面最后是a和b相等的
屏幕截图 2020-11-08 233456.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-11-27 11:25:42 | 显示全部楼层    本楼为最佳答案   
这两个写法 是不一样的,第一个写法相当于:
  1. t = a
  2. a = b%a
  3. b = t
复制代码

是把原来a的值给b,而你第二个写法里面最后是a和b相等的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-11-27 11:28:40 | 显示全部楼层
1471590985 发表于 2020-11-27 11:25
这两个写法 是不一样的,第一个写法相当于:

是把原来a的值给b,而你第二个写法里面最后是a和b相等的

原来如此
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-30 09:12

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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