鱼C论坛

 找回密码
 立即注册
查看: 2862|回复: 9

[已解决]递归

[复制链接]
发表于 2022-11-28 14:57:35 | 显示全部楼层 |阅读模式

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

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

x
def recursion(num):
    if num==1:
        return 1
    else:
        return num*recursion(num-1)
result=recursion(5)
print(result)
程序是计算1*2*3*4*5的功能,运行正常,但是我想去掉第 2-4 行,怎么就报错了?
最佳答案
2022-11-28 15:01:08
本帖最后由 jackz007 于 2022-11-28 15:03 编辑

        这个递归设置的结束条件是 num == 1,就是说,当输入参数 num = 1 的时候,就不再递归,如果去掉 2 - 4 行,递归就会失去终点,导致无穷递归,最后出错。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-11-28 15:00:22 | 显示全部楼层
去掉之后没有递归限制,程序就会一直递归,然后出现栈错误
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-28 15:01:08 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2022-11-28 15:03 编辑

        这个递归设置的结束条件是 num == 1,就是说,当输入参数 num = 1 的时候,就不再递归,如果去掉 2 - 4 行,递归就会失去终点,导致无穷递归,最后出错。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-28 15:01:41 | 显示全部楼层
递归是有深度的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-11-28 15:02:10 | 显示全部楼层
tommyyu 发表于 2022-11-28 15:00
去掉之后没有递归限制,程序就会一直递归,然后出现栈错误

程序中,已经给数据5了,不会一直递归下去的吧?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-11-28 15:04:10 | 显示全部楼层
jackz007 发表于 2022-11-28 15:01
这个递归设置了递归结束条件 num == 1,就是说,当输入参数 num = 1 的时候,就不再递归,如果去掉 ...

程序中,已经给数据5了,怎么会一直递归下去呢?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-11-28 15:06:10 | 显示全部楼层
jackz007 发表于 2022-11-28 15:01
这个递归设置的结束条件是 num == 1,就是说,当输入参数 num = 1 的时候,就不再递归,如果去掉 2 ...

哦哦,原来 n==1 是有意义的!不能省略的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-28 15:10:50 | 显示全部楼层
本帖最后由 jackz007 于 2022-11-28 15:12 编辑
dragov 发表于 2022-11-28 15:04
程序中,已经给数据5了,怎么会一直递归下去呢?


      num = 5 不等于 1,执行
return num*recursion(num-1)
      num 成了 4 ,继续递归
return num*recursion(num-1)
      num 成了 3 ,继续递归
。。。。。。
      num = 1 的时候,return 1
      于是,recursion(5) = 5 * recursion(4) = 5 * 4 * recursion(3) = 5 * 4 * 3 * recursion(2) = 5 * 4 * 3 * 2 * recursion(1) = 5 * 4 * 3 * 2 * 1
      
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-28 15:12:56 | 显示全部楼层
dragov 发表于 2022-11-28 15:06
哦哦,原来 n==1 是有意义的!不能省略的

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

使用道具 举报

发表于 2022-11-29 11:52:24 | 显示全部楼层
递归两要素:
1. 边界条件:递归一定要有边界条件,不然就会无限拆问题,在你这个例子里,f1 = 1
2. 如何拆问题:这个大问题是由哪几个小问题得出来的,意思就是说如何把大问题表示为若干小问题的形式,在你这个例子, fi = fi - 1 * i
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-25 11:11

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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