鱼C论坛

 找回密码
 立即注册
查看: 2615|回复: 6

0基础Py17课后动动手第二题!

[复制链接]
发表于 2016-3-10 22:43:46 | 显示全部楼层 |阅读模式

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

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

x
就是用欧几里得算法求最大公约数  理论上 Python应该是可以递归调用的吧  但是我没学到不太懂  这段代码为什么不能求出公约数呢
  1. def gcd(x,y):
  2.         if x > y:
  3.                 temp = x % y
  4.                 minium = y
  5.         else:
  6.                 temp = y % x
  7.                 minium = x
  8.         if temp == 0:
  9.                 return minium
  10.         else:
  11.                 gcd(minium,temp)
复制代码



是不是递归不是这么用的?
可是我看那个求阶乘也就是直接调用的呀 = =
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2016-3-10 22:54:08 | 显示全部楼层
感觉不弄懂睡不着啊= =
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-3-10 22:56:53 | 显示全部楼层
11行改为:
  1. return gcd(minium,temp)
复制代码

评分

参与人数 1鱼币 +2 收起 理由
旺仔sama + 2

查看全部评分

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

使用道具 举报

 楼主| 发表于 2016-3-10 22:59:18 | 显示全部楼层

哎  可是为什么要加上return 呢  = =
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-3-10 23:02:47 | 显示全部楼层
旺仔sama 发表于 2016-3-10 22:59
哎  可是为什么要加上return 呢  = =

这样才能使每次递归的依次返回
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-3-10 23:03:38 | 显示全部楼层
参见阶乘的例子:
  1. def fact(n):
  2.     if n==1:
  3.         return 1
  4.     return n * fact(n - 1)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2016-3-10 23:07:16 | 显示全部楼层
冬雪雪冬 发表于 2016-3-10 23:02
这样才能使每次递归的依次返回

好像明白了  = =  谢谢版主大大
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-20 04:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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