幂次方(c++题解)

题目描述

任何一个正整数都可以用 22 的幂次方表示。例如 137=2^7+2^3+2^0。

同时约定方次用括号来表示,即 a^b 可表示为 a(b)。

由此可知,137137 可表示为 2(7)+2(3)+2(0)

进一步:

7= 2^2+2+2^0 ( 2^121 用 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(0))+2+2(0)。

输入格式

一行一个正整数 n。

输出格式

符合约定的 n 的 0,2 表示(在表示中不能有空格)。

输入输出样例

输入 #1复制

复制代码
1315

输出 #1复制

复制代码
2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0)

写作不易,点个赞呗!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!


cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n;
void dfs(int s){
	for(int i=log2(s)+1;i>=0;i--){
		if(s>=pow(2,i))	{
			if(i==2){
				cout<<"2(2)";
			}
			else if(i==1){
				cout<<"2";
			}
			 else if(i==0){
				cout<<"2(0)";
			}
			 else{
				 cout<<"2(";
				dfs(log2(s));
				cout<<")";
			}
			s-=pow(2,i);
			if(s!=0){
				cout<<"+";
			}
		}
	}
}

int main()
{
	cin>>n;
	dfs(n);
	return 0;
}
相关推荐
一起搞IT吧几秒前
Android功耗系列专题理论之十六:功耗不同阶段&不同模块分析说明
android·c++·智能手机·性能优化
炸膛坦客1 分钟前
单片机/C语言八股:(十三)C 语言实现矩阵乘法
c语言·开发语言·矩阵
荣光属于凯撒19 分钟前
P15755 [JAG 2025 Summer Camp #1] JAG Box
c++·算法·贪心算法
为你奋斗!26 分钟前
Playwright 录屏功能启用离线安装依赖pywin32 pillow
开发语言·chrome·python·语言模型·迁移学习
郝学胜-神的一滴26 分钟前
CMake:解锁C++跨平台工程构建的核心密钥
开发语言·c++·职场和发展
zh路西法26 分钟前
【宇树机器人强化学习】(二):ActorCritic网络和ActorCriticRecurrent网络的python实现与解析
开发语言·python·深度学习·机器学习·机器人
沐知全栈开发28 分钟前
MVC 控制器
开发语言
wjs202432 分钟前
ECharts 交互组件:深入解析与实战应用
开发语言
!chen33 分钟前
C# + ViewFaceCore 快速实现高精度人脸识别
开发语言·c#
佑白雪乐34 分钟前
C++标准总结+VSCode使用+MinGW
开发语言·c++·vscode