递归函数内部的执行顺序


  
  
  1. #include <stdio.h>
  2. void fun(int n)
  3. {
  4. printf( "1th - Level: %d Address: %d\n", n, &n);
  5. if(n < 3)
  6. fun(n+1);
  7. printf( "2th - Level: %d Address: %d\n", n, &n);
  8. }
  9. int main()
  10. {
  11. fun(1);
  12. return 0;
  13. }

输出结果:

分析:

1) 主函数调用fun(1);
2) 此时n的值为1,随即输出第一行,并得到n的地址并将其抽象为aaaa;
3) 判断,1 < 3,执行递归语句, 重新执行fun函数;
4) 由于传递参数为n+1,所以本层n的值为2,随即输出第二行,并得到n的新地址将其抽象为bbbb;
5) 判断,2 < 3,执行递归语句, 重新执行fun函数;
6) 同理可得本层n的值为3,得到第三行结果,并将n的新地址抽象为cccc;
7) 判断,3 < 3不成立,不执行递归, 直接执行第二条输出语句,即输出第四行结果,此时显示n的地址为cccc,容易理解;
8) 本层结束,返回上一层断点处继续执行,即n为2的那一层,当时程序去已经执行递归,所以接下来执行第二次输出,即得到第五行输出结果,此时n的地址显示为bbbb;
9) n为2时的一层执行结束,返回上一层,即n为1,当时程序去已经执行递归,所以接下来执行输出语句,即得到第六行输出结果,此时n的地址显示为aaaa;

程序结束。

总结:
1. 每一级的递归都使用它自己的私有的变量n,可以查看地址的值来证明。
2. 每一次函数调用都会有一次返回.当程序流执行到某一级递归的结尾处时,它会转移到前一级递归继续执行。
3. 位于递归调用语句前的语句的执行顺序和各个被调用函数的顺序相同,位于递归调用语句后的语句的执行顺序和各个被调用函数的顺序相反。

4. 递归函数中必须包含可以终止递归调用的语句来避免死循环。

带返回值:


  
  
  1. #include <stdio.h>
  2. int fun(int n)
  3. {
  4. if(n> 3)
  5. return n;
  6. printf( "1th - Level: %d Address: %d\n", n, &n);
  7. int result = fun(n+1);
  8. printf( "2th - Level: %d Address: %d\n", n, &n);
  9. printf( "2th - result: %d\n", result);
  10. return n;
  11. }
  12. int main()
  13. {
  14. int result = fun(1);
  15. printf( "main - result: %d\n", result);
  16. return 0;
  17. }

输出结果:



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值