用递归将十进制转换成二进制

/*
 * Copyright (c) 2013, 烟台大学计算机学院
* All rights reserved.
* 作    者:王颖
* 完成日期:2013 年 11 月 21 日
* 版 本 号:v1.0
*
* 输入描述: 无
* 问题描述:用递归将十进制数转换成二进制
* 程序输出:略
* 问题分析:略
* 算法设计:略
*/
#include <iostream>

using namespace std;
void dec2bin(int n);//函数声明
int main()
{
    int n;                            //n为需要输入的整数
    cout<<"请输入一个整数:";
    cin>>n;
    if(n<0)
    {
        cout<<"必须为正数!"<<endl;
    }
    else{
    cout<<n<<"对应的二进制形式为:";
    dec2bin(n);                       //调用得出dec2bin函数以求出二进制
    }

    cout<<endl;
    return 0;
}
void dec2bin(int a)                    //递归函数
{
    if (a==0)
        cout<<endl;                            //如果a<0直接返回
    else                               //进行递归调用
    {
        dec2bin(a/2);
        cout<<a%2;
            }
return ;
}


刚开始做的很复杂,也没有想到正负数的情况,没办法,又回头看例题,慢慢了解的过程其实很慢,但是明白了之后会好些。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值