/*
*一个十进制数,按题目要求转换为特定形式。
*输入291,二进制数为100100011
*291=2(8)+2(5)+2(1)+2(0)
*但是8也必须转换为特定的形式,除2(1) 2(2) 2(0)不用转换外。
*最终输出为:2(2(2(1)+2(0)))+2(2(2)+2(0))+2(1)+2(0)
*/
#include<iostream>
using namespace std;
//转换函数
void dec_to_2(int num);
//求2^n函数
int n_2(int n);
int main()
{
int dec_num = 0;
cout << "place input num: ";
cin >> dec_num;
cout << dec_num << " = ";
//函数调用
dec_to_2(dec_num);
cout << "\n";
return 0;
}
//转换函数
void dec_to_2(int num)
{
int temp = num;//定义临时变量用于储存下一次递归传入参数
int count_num = 0;
//2进制计算
while(num > 1)
{
num /= 2;
++count_num;
}
//打印
if(num != 0)//num为2的倍数时不打印2(0)
{
cout <<"2(" ;
if(count_num != 0 && count_num !=1 &&
count_num !=2)
{
dec_to_2(count_num );
}
else//防止递归后程序沿原路径返回 count_num 值
{
cout << count_num;
}
cout << ")";
}
//递归调用
if(temp > 1 && (temp !=
n_2(count_num)))//num为2的倍数时末尾不打印'+'
{
cout << " + ";
dec_to_2(temp%(n_2(count_num)));
}
}
//求2^n函数
int n_2(int n)
{
int temp = 1;
while(n != 0)
{
temp *= 2;
--n;
}
return temp;
}
结果如下
place input num: 291
291 = 2(2(2(1) + 2(0))) + 2(2(2) + 2(0)) + 2(1) + 2(0)
Press any key to continue . . .
初学者感觉有点瞎写的,优化什么的没考虑。。。。