洛谷P1010 [NOIP1998 普及组] 幂次方 题解

题目

C++:

#include
using namespace std;
string run(int x,int i=0,string s=string("")){
	if(x==0)return string("0");
	do if(x&1)s=(i==1?"2":"2("+run(i)+")")+(s==""?"":"+")+s;//拼接字符串,应题意,要把低次方接在后面
	while(++i,x>>=1);//每次向右移位
	return s;
}
int main(){
	int x;cin>>x;
	cout<

你可能感兴趣的:(c++,算法)