鱼C论坛

 找回密码
 立即注册
查看: 1412|回复: 8

[已解决]递归返回问题

[复制链接]
发表于 2020-11-18 21:04:22 | 显示全部楼层 |阅读模式

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

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

x
def power(x, y):
    if y:
        return x * power(x, y-1)
    else:
        return 1
   
print(power(2, 3))

return x * power(x, y-1)这句我应该怎么理解?
最佳答案
2020-11-18 21:14:53
本帖最后由 Twilight6 于 2020-11-18 21:17 编辑


语言不好叙述,直接举例子吧:

假设 x = 2 , y = 3

调用 power(x, y) 将 x ,y代入函数 :

power(2, 3) --> if 3 --> True --> return 2 * power(2, 3-1)

而 power(2, 3-1)  开始第一次递归:

power(2, 2)  --> if 2 --> True --> return 2 * power(2 , 2-1)

而 power(2, 2-1)  开始第二次递归:

power(2, 1)  --> if 1 --> True --> return 2 * power(2 , 1-1)

而 power(2, 1-1)  开始第三次递归:

power(2, 0)  --> if 0 --> False --> else -->  return 1

递归进入,依次返回:2 * 2 * 2 * 1

即 power(2, 3)  函数 return 2 * 2 * 2 * 1



想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-11-18 21:06:58 | 显示全部楼层
本帖最后由 昨非 于 2020-11-18 21:08 编辑

就相当于
  1. a=x * power(x, y-1)
  2. return a
复制代码

在返回的同时递归调用自己

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-18 21:10:15 | 显示全部楼层
本帖最后由 昨非 于 2020-11-18 21:17 编辑

执行:2的3次方->return 2*【执行:2的3-1次方】
执行:2的3-1次方->return 2*【执行:2的3-1-1次方】
执行:2的3-1-1次方->return 2*【执行:2的0次方】
执行:2的0次方->return 1     到这里结束,下面是一层层返回的过程

第一次返回:1*2
第二次返回:1*2*2
最后一次返回:1*2*2*2
返回结果就是2的3次方
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-18 21:13:55 | 显示全部楼层
能写一下详细的运算步骤吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-18 21:14:14 | 显示全部楼层
zyj1214 发表于 2020-11-18 21:13
能写一下详细的运算步骤吗?

看二楼
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-18 21:14:53 | 显示全部楼层    本楼为最佳答案   
本帖最后由 Twilight6 于 2020-11-18 21:17 编辑


语言不好叙述,直接举例子吧:

假设 x = 2 , y = 3

调用 power(x, y) 将 x ,y代入函数 :

power(2, 3) --> if 3 --> True --> return 2 * power(2, 3-1)

而 power(2, 3-1)  开始第一次递归:

power(2, 2)  --> if 2 --> True --> return 2 * power(2 , 2-1)

而 power(2, 2-1)  开始第二次递归:

power(2, 1)  --> if 1 --> True --> return 2 * power(2 , 1-1)

而 power(2, 1-1)  开始第三次递归:

power(2, 0)  --> if 0 --> False --> else -->  return 1

递归进入,依次返回:2 * 2 * 2 * 1

即 power(2, 3)  函数 return 2 * 2 * 2 * 1



想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-18 21:25:23 | 显示全部楼层
我是不是该这样理解:
a=x * power(x, y-1)
power(2,3)传入 power(x, y-1)
等于2× power(2, 3-1)  #power(2, 3-1)在传入 power(x, y-1)  y=2
等于2×(2× power(2, 2-1))#power(2, 2-1)在传入 power(x, y-1)  y=1
等于2×(2×(2*power(2,1-1)))#power(2, 1-1)在传入 power(x, y-1)  y=0

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-18 21:26:36 | 显示全部楼层
zyj1214 发表于 2020-11-18 21:25
我是不是该这样理解:
a=x * power(x, y-1)
power(2,3)传入 power(x, y-1)



是的,正解

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-18 21:27:50 | 显示全部楼层
zyj1214 发表于 2020-11-18 21:25
我是不是该这样理解:
a=x * power(x, y-1)
power(2,3)传入 power(x, y-1)


差不多,也就是每层递归调用第二个参数逐渐从3减到0
返回的依次是1,2*1,2*2*1,2*2*2*1,也就是8(结果)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-1 16:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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