- 1、本文档共23页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构与算法实用教程
主编 高佳琴
第6章 递 归
本章要点:
1) 递归的基本概念和实现原理,用递归的思想
描述问题和书写算法的方法。
2) 阶乘等问题的递归解法。
3) 用非递归方式来实现递归问题的非递归解法
(例如用循环、栈等实现)。
本章难点:
递归算法的非递归解决方法。
第6章 递 归
6.1 递归的基本概念和实现原理
6.2 递归算法实现
6.3 递归问题的非递归实现
6.1 递归的基本概念和实现原理
(1) 递归就是在过程或函数里调用自身。
(2) 在使用递归策略时,必须有一个明确的递归结束条件,称为递
归出口。
1.问题的定义是递归的
2.递归过程与递归工作栈
3.数据结构本身是递归的
4. 问题的解法是递归的
(2) 在使用递归策略时,必须有一个明确的递归结束条件,称为递
归出口。
1) 定义是递归的:在定义的过程中又引用了定义本身,有很多
数学函数有这种情况。
2) 数据结构是递归的:指数据结构中又包含了与本身相同的数据
结构。
3) 解决问题的方法是递归的:在解决问题的过程中发现可以用相
同方法反复调用去处理问题。
1.问题的定义是递归的
例6-2 中,求解Fib(n) ,把它推到求解Fib(n-1)和Fib(n-2) 。也就是说,为计算
Fib(n) ,必须先计算Fib(n-1)和Fib(n-2) ,而计算Fib(n-1)和Fib(n-2) ,又必须先
计算Fib(n-3)和Fib(n-4) 。依此类推,直至计算Fib(1)和Fib(0) ,分别能立即得
到结果1和0 。在递推阶段,必须要有终止递归的情况。例如在函数Fib 中,
当n为1和0的情况。斐波那契数列的函数运行时的分解图如图6-2所示。
1.问题的定义是递归的
图6-1 求解n! 的递归算法
1.问题的定义是递归的
图6-2 Fib函数分解图
1.问题的定义是递归的
例6-2 中,求解Fib(n) ,把它推到求解Fib(n-1)和Fib(n-2) 。也就是
说,为计算Fib(n) ,必须先计算Fib(n-1)和Fib(n-2) ,而计算Fib(n-1)
和Fib(n-2) ,又必须先计算Fib(n-3)和Fib(n-4) 。依此类推,直至计算
Fib(1)和Fib(0) ,分别能立即得到结果1和0 。在递推阶段,必须要有
终止递归的情况。例如在函数Fib 中,当n为1和0的情况。斐波那契
数列的函数运行时的分解图如图6-2所示。
2.递归过程与递归工作栈
1) 将所有的实在参数、返回地址等信息传递给被调用函数保存。
2) 为被调用函数的局部变量分配存储区。
3) 将控制转移到被调用函数的入口。
1) 保存被调用函数的计算结果。
2) 释放被调用函数的数据区。
3) 依照被调用函数保存的上一层的返回地址将控制转移到调用函数。
1) 本次函数调用时的实在参数(函数名、数值等) 。
2) 返回地址(即上层中本次调用的语句的下一条语句或指令地址) 。
3) 本层的局部变量。
2.递归过程与递归工作栈
图6-3 一次函数调用过程
3.数据结构本身是递归的
图6-4 单链表数据结构递归
4. 问题的解法是递归的
有很多问题只要经过分析,能够找到递归的成份就可以用递归
去解决。
6.2 递归算法实现
6.2.1 递归算法实现的基本步骤
6.2.2 递归的应用
6.2.1 递归算法实现的基本步骤
1) 确立边界条件: 找到递归终止的条件, 确定与递归出口相对应
的操作。
2) 确定递归体所对
您可能关注的文档
- 生产系统建模与仿真 教学配套课件 周泓 7_仿真模型的校核、验证与确认.pdf
- 生产系统建模与仿真 教学配套课件 周泓 8_面向生产系统的仿真软件.pdf
- 生产系统建模与仿真 教学配套课件 周泓 9_基于多主体的大规模复杂系统建模与仿真技术.pdf
- 施工组织设计 教学配套课件 卢青 单元1 施工组织设计的基本理论.pdf
- 施工组织设计 教学配套课件 卢青 单元2 施工方案的设计.pdf
- 施工组织设计 教学配套课件 卢青 单元3 流水施工的组织.pdf
- 施工组织设计 教学配套课件 卢青 单元4 网络计划技术.pdf
- 施工组织设计 教学配套课件 卢青 单元5 单位工程施工进度计划的编制.pdf
- 施工组织设计 教学配套课件 卢青 单元6 单位工程施工平面图的设计.pdf
- 施工组织设计 教学配套课件 卢青 单元7 单位工程施工组织设计实例.pdf
- 2025年一级建造师考试《水利水电工程管理与实务》冲刺必刷卷.docx
- 2025年一级建造师考试《水利水电工程管理与实务》逆袭破题卷1.docx
- 2025年一级建造师考试《市政工程管理与实务》冲刺必刷卷 .docx
- 2025年一级造价工程师考试《建设工程计价》预习卷.docx
- 2025年一级造价工程师考试《建设工程造价管理》预习卷.docx
- 2025年一级造价工程师考试《建设工程造价案例分析(安装专业)》预习卷.docx
- 2025年一级造价工程师考试《建设工程造价案例分析(土建专业)》预习卷.docx
- 2025年中级会计考试《会计实务》冲刺提分卷.docx
- 2025年中级会计考试《财务管理》冲刺提分卷.docx
- 2025年中级会计考试《财务管理》全真模拟卷.docx
文档评论(0)