递归细说

int vesursion(int n)

{

printf("%d\n",n);

if(n>1)

{

printf("递归前n=%d\n",n);

}

else

{

printf("结束递归n=%d\n",n);

}

printf("递归后n=%d\n",n);

}

void main()

{

recursion(3);

}

输出结果:递归前n=3

                  递归前n=2

                  递归前n=1

                 结束递归n=1

                  递归后n=1

                  递归后n=2

                  递归后n=3

递归的核心就在递归后的三个输出,因为程序每进行一次递归都会进行一次压栈,栈是先进后出,因此n=3时第一次递归,n=1最后一次递归,因此递归后先出输出3,最后输出1.

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值