递归函数内部的执行顺序

网友投稿 679 2022-12-01

递归函数内部的执行顺序

递归函数内部的执行顺序

#include void fun(int n) { printf("1th - Level: %d Address: %d\n", n, &n); if(n < 3) fun(n+1); printf("2th - Level: %d Address: %d\n", n, &n); } int main() { fun(1); return 0; }

输出结果:

分析:

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. 递归函数中必须包含可以终止递归调用的语句来避免死循环。

带返回值:

#include int fun(int n){ if(n>3) return n; printf("1th - Level: %d Address: %d\n", n, &n); int result = fun(n+1); printf("2th - Level: %d Address: %d\n", n, &n); printf("2th - result: %d\n", result); return n;}int main(){ int result = fun(1); printf("main - result: %d\n", result); return 0;}

输出结果:

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:QML之自定义滚动条
下一篇:Qt换肤之二:基于QSS+XML
相关文章

 发表评论

暂时没有评论,来抢沙发吧~