鱼C论坛

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

[已解决]求各位大神讲一讲递归的原理和提供点资料谢谢

[复制链接]
发表于 2020-9-28 20:45:44 | 显示全部楼层 |阅读模式

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

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

x
求各位大神讲一讲递归的原理和提供点资料谢谢
最佳答案
2020-9-28 21:54:39
Python 我不会,递归嘛,具体来讲就是把规模大的问题转化为规模小的相似的子问题来解决。在函数实现时,因为解决大问题的方法和解决小问题的方法往往是同一个方法,所以就产生了函数调用它自身的情况。另外这个解决问题的函数必须有明显的结束条件,这样就不会产生无限递归的情况了。

递归的两个条件:

可以通过递归调用来缩小问题规模,且新问题与原问题有着相同的形式。(自身调用)
存在一种简单情境,可以使递归在简单情境下退出。

求阶乘是最好的递归例子:

第一步:5!=5*4!转而计算4!

第二步:4!=4*3!转而计算3!

第三步:3!=3*2!转而计算2!

第四步:2!=2*1!转而计算1!

第五步:1!=1  递归出口

然后再反向计算出结果。

本帖被以下淘专辑推荐:

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

使用道具 举报

发表于 2020-9-28 21:51:26 | 显示全部楼层
问度娘吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-28 21:54:39 | 显示全部楼层    本楼为最佳答案   
Python 我不会,递归嘛,具体来讲就是把规模大的问题转化为规模小的相似的子问题来解决。在函数实现时,因为解决大问题的方法和解决小问题的方法往往是同一个方法,所以就产生了函数调用它自身的情况。另外这个解决问题的函数必须有明显的结束条件,这样就不会产生无限递归的情况了。

递归的两个条件:

可以通过递归调用来缩小问题规模,且新问题与原问题有着相同的形式。(自身调用)
存在一种简单情境,可以使递归在简单情境下退出。

求阶乘是最好的递归例子:

第一步:5!=5*4!转而计算4!

第二步:4!=4*3!转而计算3!

第三步:3!=3*2!转而计算2!

第四步:2!=2*1!转而计算1!

第五步:1!=1  递归出口

然后再反向计算出结果。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-18 11:54

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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