3.3 栈与递归的实现

举报
C语言入门到精通 发表于 2021/02/09 22:37:25 2021/02/09
【摘要】 01栈与递归1、栈还有一个重要应用是在程序设计语言中实现递归。一个直接调用自己或通过一系列的调用语句间接调用自己的函数,称做递归函数。2、在高级语言编制的程序中,调用函数和调用函数之间的链接及信息交换需要通过栈来进行。02实现 1、当在一个函数的运行期间调用另一个函数时,在运行被调用函数之前,系统需先完成3件事:(1)将所有的实在参数、返回地址等信息传递给被调用函数保存。(2)...

01栈与递归


1、栈还有一个重要应用是在程序设计语言中实现递归。一个直接调用自己或通过一系列的调用语句间接调用自己的函数,称做递归函数。

2、在高级语言编制的程序中,调用函数和调用函数之间的链接及信息交换需要通过栈来进行。


02实现


1、当在一个函数的运行期间调用另一个函数时,在运行被调用函数之前,系统需先完成3件事:

(1)将所有的实在参数、返回地址等信息传递给被调用函数保存。

(2)为被调用函数的局部变量分配存储区。

(3)将控制转移到被调函数的入口。

2、从被调函数返回调用函数之前,系统也应该完成3件工作:

(1)保存被调函数的计算结果。

(2)释放被调函数的数据区。

(3)依照被调函数保存的返回地址将控制转移到调用函数。

3、一个递归函数的运行过程类似于多个函数的嵌套调用,只是调用函数和被调函数是同一个函数,因此,和每次调用相关的一个重要的概念是递归函数运行的“层次”。

C语言 | 计算存款本息和(2) mp.weixin.qq.com图标

文章来源: zhuanlan.zhihu.com,作者:小林C语言,版权归原作者所有,如需转载,请联系作者。

原文链接:zhuanlan.zhihu.com/p/337364747

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。