鱼C论坛

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

[已解决]关于22课的递归欧几里得算法

[复制链接]
发表于 2018-5-8 11:46:31 | 显示全部楼层 |阅读模式

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

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

x
题目中说要用欧几里得算法求公约数,我写了个代码如下:
def gcd(x,y):
      if y>x:
            x,y=y,x
            gcd(x,y)
      else:
            t=x%y
            if t!=0:
                  x,y=y,t
                  gcd(x,y)
            else:
                  return y

运行后没有返回值,把最后的return y 改成 print(y)就恢复正常了。
在其他的题目里面使用 return 都可以得到返回值,这里就不行,所以想请问一下是为什么?问题出现在哪里?
谢谢大神!

最佳答案
2018-5-8 12:56:27
  1. def gcd(x,y):
  2.     if y>x:
  3.         x,y=y,x
  4.         return gcd(x,y)
  5.     else:
  6.         t=x%y
  7.         if t!=0:
  8.             x,y=y,t
  9.             return gcd(x,y)
  10.         else:
  11.             return y
复制代码


你那个只有纯素数应该才可以,上面修改成这样就好了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-5-8 11:51:27 | 显示全部楼层
只有最后一层递归的时候返回的是所需的值
其他递归层默认返回的都是None
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-5-8 12:56:27 | 显示全部楼层    本楼为最佳答案   
  1. def gcd(x,y):
  2.     if y>x:
  3.         x,y=y,x
  4.         return gcd(x,y)
  5.     else:
  6.         t=x%y
  7.         if t!=0:
  8.             x,y=y,t
  9.             return gcd(x,y)
  10.         else:
  11.             return y
复制代码


你那个只有纯素数应该才可以,上面修改成这样就好了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-5-8 13:28:28 | 显示全部楼层
第四行加个return 就可以了.我也刚犯过同样的错误
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-28 13:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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