关注
/*
*一个十进制数,按题目要求转换为特定形式。
*输入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 . . .
初学者感觉有点瞎写的,优化什么的没考虑。。。。
查看原帖
点赞 1
相关推荐
12-19 19:32
上海理工大学 产品经理 点赞 评论 收藏
分享
11-23 20:47
中国地质大学(武汉) Java
程序员牛肉:继续沉淀吧同学,你这就是纯纯的流水线产品。
差不多的学历+两个烂大街项目。自身学历又不行,现在找啥实习呢。有点太浮躁了。多花点心思搞搞ai,开源和八股。这比你这段时间捣鼓一段小厂实习要好得多; 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 你小心翼翼的闯过多大的祸? #
4115次浏览 69人参与
# 找不到实习会影响秋招吗 #
1399946次浏览 13635人参与
# 实习没事做是福还是祸? #
4535次浏览 68人参与
# 重来一次,你会对开始求职的自己说 #
957次浏览 19人参与
# 2025年终总结 #
134899次浏览 2298人参与
# 考研人,我有话说 #
156631次浏览 1211人参与
# 哪些公司笔/面试难度大? #
7087次浏览 32人参与
# 实习简历求拷打 #
24374次浏览 250人参与
# 你觉得现在还能进互联网吗? #
29970次浏览 201人参与
# 携程工作体验 #
18963次浏览 66人参与
# 大厂VS公务员你怎么选 #
69155次浏览 638人参与
# 扒一扒那些奇葩实习经历 #
140203次浏览 1149人参与
# 找不到好工作选择GAP真的丢人吗 #
93734次浏览 1007人参与
# 那些我实习了才知道的事 #
253157次浏览 1785人参与
# 非技术投递记录 #
672986次浏览 6821人参与
# 机械求职避坑tips #
81098次浏览 531人参与
# 投格力的你,拿到offer了吗? #
155028次浏览 829人参与
# 第一份工作能做外包吗? #
94096次浏览 599人参与
# 作业帮求职进展汇总 #
85534次浏览 559人参与
# 秋招遇到的奇葩面试题 #
101275次浏览 416人参与