C语言--函数递归

递归函数是自己调用自己的函数,每次调用函数都会开辟新的内存空间,递归调用可以看成函数的嵌套调用 ,通俗来说,递归就是一个函数在它的函数体内调用它自身。

下面举个例子:

根据下面递归函数:调用函数Fun(2),返回值是多少?

int Fun(int n)      
{ 
  if(n==5)   
    return 2;     
  else     
    return 2*Fun(n+1);      
}

 文字说明(红色代表递归,绿色代表返回,先看红色再看绿色):

调用函数Fun(2),

1.首先传入2,判断是否等于5,不等于5继续调用Fun()函数

2.直到Fun(5)时,返回2给上一层的Fun(4),以此类推,返回到第一层得出结果16

 

递归效率不高,由于栈的大小不是无限大的,所以递归调用次数过多,会导致栈溢出。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值