简单理解递归

递归

​ 递🐢? obviously,no!

​ 简单来说就是一个函数自己调用自己。

#include<iostream>
using namespace std;
void function(int n){
    if(n > 0)function(n - 1);
    cout<<n<<endl;
}
int main(){
    function(3);
    return 0;
}

​ 每调用一次自己就会在栈中开辟一个新的空间来执行该函数。

​ 先在主函数空间执行,

​ 执行到function(3);时,开辟空间执行function(3),

​ 此时n = 3,n > 0,执行function(3 - 1),开辟空间执行function(2),

​ 此时n = 2,n > 0,执行function( 2 - 1),开辟空间执行function(1),

​ 此时n == 1,n > 0,执行function( 1- 1),开辟空间执行function(0),

​ 此时n == 0, 执行输出语句,输出0,

​ 由于function(1)还有语句没执行完,

​ 然后返回执行,function(1)的输出语句,输出1,

​ 由于function(2)还有语句没执行完,

​ 然后返回执行,function(2)的输出语句,输出2,

​ 由于function(3)还有语句没执行完

​ 然后返回执行,function(2)的输出语句,输出3。

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值