网站大量收购独家精品文档,联系QQ:2885784924

棧与递归的实现.docVIP

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
棧与递归的实现

论文题目:栈与递归的关系 年 级 专 业信息与计算科学101 姓 名 学 号 日期: 2012.11.1 目 录 内容提要-----------------------------------------------3 关键字--------------------------------------------------3 正文 第一部分:递归的设计步骤---------------------------------4 第二部分:举例说明-----------------------------------------4 (1)进制转换的栈与递归的实现------------------------5 (2)算阶乘的栈与递归的实现---------------------------7 hanio塔的栈与递归的实现------------------------9 第三部分: 阐述递归与栈的关系(递归在计算机中的实现以阶乘为例)----------------------------------------------------------10 总结------------------------------------------------------12 参考文献------------------------------------------------13 栈与递归的关系 内容提要 在本篇论文中主要是讨论下栈与递归的关系,一个直接调用自己或者通过一系列的调用的语句间接地调用自己的函数,称作为递归函数。调用函数与被调用函数直接的链接以及信息的交换就是通过栈来进行。 通常,当一个函数的运行期间调用另一个函数的时候,在运行被调用函数之前,系统都会先完成3件事:(1)将所有的实在参数、返回地址等信息传递给被调用的函数保存;(2)为被调用的局部变量分配存储区;(3)将控制转移到被调用的函数的入口。而从被调用函数返回调用函数之前,系统也应完成三件事:(1)保存被调用函数的计算结果;(2)释放被调用函数的数据区;(3)依照被调用函数保存的返回地址将控制转移到调用函数上。当有多个函数构成嵌套语句时,按照,“后调用先返回”的原则,上述的函数之间的信息传递和控制的转移必须通过“栈”来实现,即系统将整个程序运行时间所需的数据安排在一个栈中,每当调用一个函数时,就为它在栈顶分配一个存储区,每当一个函数退出时,就释放它的存储空间,则当前正在运行的函数的数据区必在栈顶。也即是说:计算机执行递归算法时,是通过栈来实现的。具体说来,就是在(递归过程或递归函数)开始运行时,系统首先为递归建立一个栈,该栈的元素类型(数据域)包括值参、局部变量和返回地址;在每次执行递归调用语句时之前,自动把本算法中所使用的值参和局部变量的当前值以及调用后的返回地址压栈(一般形象地称为“保存现场”,以便需要时“恢复现场”返回到某一状态),在每次递归调用结束后,又自动把栈顶元素(各个域)的值分别赋给相应的值参和局部变量(出栈),以便使它们恢复到调用前的值,接着无条件转向(返回)由返回地址所指定的位置继续执行算法。 所以实际上,在调用函数和被调用函数之间不仅会传递参数的值,也可以传递参数的地址。在C语言中,对递归问题的编程时,不需要用户自己,而是由系统来管理递归工作栈。 关键词 栈与递归 正文 正文分成三个部分进行阐述: 第一部分:递归的含义以及设计步骤和技巧 第二部分:函数递归的应用例子 第三部分:阐述递归与栈的关系(递归在计算机中的实现以阶乘为例) 第一部分:递归的含义以及设计步骤和技巧 (1) 递归的含义  所谓递归是指:若在一个函数、过程或者数据结构定义的内部,直接(或间接)出现定义本身的应用,则称它们是递归的,或者是递归定义的。  递归是一种强有力的数学工具,它可使问题的描述和求解变得简洁和清晰。 递归算法常常比非递归算法更易设计,尤其是当问题本身或所涉及的数据结构是递归定义的时候,使用递归算法特别合适 (2)递归算法的设计步骤  第一步骤(递归步骤):将规模较大的原问

您可能关注的文档

文档评论(0)

fv45ffsjjI + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档