递归调用

以下面一段利用函数递归调用的代码为例:

#include<stdio.h>
int Age(int n)
{
 if(n==1)//第一个人的年龄为10
 {
  return 10;
 }
 else //其余每人的年龄都是其前一个人的年龄加2
 {
  return Age(n-1)+2;
 }
}
int main()
{
 printf("%d\n",Age(5));  //打印Age(5)的值
 return 0;
}

在这里插入图片描述
如图所示,当n=5时,Age(5)=Age(4)+2,需要先求Age(4),而Age(4)=Age(3)+2,又要先得出Age(3),…,以此类推,当n=1时,Age(1)=10,知道Age(1),便可得出Age(2),再推出Age(3),…,最后得出Age(5)的值。
C语言中,每个栈帧对应着一个未运行完的函数。栈帧中保存了该函数的返回地址和局部变量。
递归算法一般的空间复杂度较大,上述该算法的空间复杂度为O(n)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值