资源限制
内存限制:512.0MB C/C++时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s
问题描述
任何一个正整数都可以用2进制表示,例如:137的2进制表示为10001001。
将这种2进制表示写成2的次幂的和的形式,令次幂高的排在前面,可得到如下表达式:137=2^7+2^3+2^0
现在约定幂次用括号来表示,即a^b表示为a(b)
此时,137可表示为:2(7)+2(3)+2(0)
进一步:7=2^2+2+2^0 (2^1用2表示)
3=2+2^0
所以最后137可表示为:2(2(2)+2+2(0))+2(2+2(0))+2(0)
又如:1315=2^10+2^8+2^5+2+1
所以1315最后可表示为:
2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0)
输入格式
正整数(1<=n<=20000)
输出格式
符合约定的n的0,2表示(在表示中不能有空格)
样例输入
137
样例输出
2(2(2)+2+2(0))+2(2+2(0))+2(0)
样例输入
1315
样例输出
2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0)
提示
用递归实现会比较简单,可以一边递归一边输出
注:题目来自蓝桥杯官网
题解:因题目给出了数字n的范围,本题可采用递归把大数逐步从2的高次幂进行分解,按照题目给定的要求进行输出,如果次幂还能继续分解,就接着递归直至最简。
代码:
#include<bits/stdc++.h>
using namespace std;
int m[15] = {1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384};//设置2的0-15次幂数组
void solve(int n)
{
for(int i = 14; i >= 0; i--)
{
if(n >= m[i])
{
n -= m[i];
if(i == 0)
cout << "2(0)";
else if(i == 1)
cout << "2";
else if(i == 2)
cout << "2(2)";
else//如果括号里还可表示为2的2次幂以上,则要继续递归
{
cout << "2";
cout << "(";
solve(i);
cout << ")";
}
if(n != 0)//如果该数没有减完,就输出"+"
cout << "+";
}
}
}
int main()
{
int a;
while(cin >> a)
{
solve(a);
cout << endl;
}
return 0;
}