博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
递归函数的深入理解,很多人的理解误区
阅读量:6297 次
发布时间:2019-06-22

本文共 817 字,大约阅读时间需要 2 分钟。

很久没时间发笔记了,这次抽空 sky(我的昵称) 再为大家讲解一个东东,讲的不好之处大神勿喷哈

#include<iostream>
using namespace std;
void bin(const unsigned int &i)
{
    
    if (i/2)
        bin(i/2);
    cout << i%2;
}
int main()
{
    int a;
    cin >> a;
    bin(a);
    cout << endl;
    return 0;
}
这是一个求一个数的二进制的程序,
对于这样的递归函数大家肯定不陌生,但是相信很多人还是不清楚它的执行过程吧,或者误以为自己想的是对的,下面我将为大家解答:
      递归函数是如何结束的呢?就是递归函数结束的标志,在本程序中,递归函数结束的标志就是if(i/2)为假,
则递归函数结束。
      程序执行是这样的,如果传进来的数是6,那么第一次if()判断为真,则执行bin(i/2),执行完后还会执行cout << i%2;不过这一句只是將它入栈了,不会在屏幕上面输出,这样才是递归函数第一次进行递归,第二次进入的时候会把第二次的cout << i%2;入栈,以此类推,直到当判断到if()为假的时候,这时递归才会结束,此时开始出栈,栈是先进后出,所以才是先输出最后执行的cout << i%2;
       很多人都认为第一次执行bin()的话就不会执行cout << i%2;了,这样的理解是错误的,因为递归就是在反复地调用函数本身,调用函数就是一个入栈的过程,如果实在不理解的话大家可以把程序反汇编一下看下编译器执行的过程就知道了。

 

欢迎与本人交流

 

新浪博客:http://blog.sina.com.cn/u/2049150530

csdn博客:http://blog.csdn.net/u011749143
博客园:http://www.cnblogs.com/sky-heaven/

 

新浪微博:张昺华--sky

 

你可能感兴趣的文章
ASP.NET 大文件下载的实现思路及代码
查看>>
win2008 域服务器搭建教程
查看>>
不用Office自动化技术,给Word文档中填充赋值
查看>>
演示:IPv6全球单播地址的配置
查看>>
JS字符串的下划线命名和驼峰命名转换
查看>>
我的友情链接
查看>>
我的第一篇博文
查看>>
网络命令
查看>>
Oracle数据库的基本语法
查看>>
为什么淘宝、天猫和旺信的 App 不整合成一个?
查看>>
nginx 访问控制 防盗链
查看>>
eclipse配置maven插件
查看>>
Hessian RPC示例和基于Http请求的Hessian序列化对象传输
查看>>
finalspeed安装及使用教程
查看>>
NEO从源码分析看数字资产
查看>>
工作中的一次linux防范ddos***___转载
查看>>
移动端高清、多屏适配方案
查看>>
SMP和MPP解析
查看>>
Redis实战(12)订阅和发布消息
查看>>
Mac OS X 创新卡关三年,唯一看得出版本不同之处是「预设桌布」
查看>>