/*
* 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 ;
}
刚开始做的很复杂,也没有想到正负数的情况,没办法,又回头看例题,慢慢了解的过程其实很慢,但是明白了之后会好些。。