提交时间:2024-08-20 17:01:11

运行 ID: 169756

#include<bits/stdc++.h> using namespace std; void solve(int k){ int i; for(i=40;i>=0;i--) { if(pow(2,i)<=k) { if(i==1)printf("2"); else if(i==0)printf("2(0)"); else { printf("2("); solve(i+1); printf(")"); } k-=pow(2,i); if(k!=0)printf("+"); } } } int main(){ int n; scanf("%d",&n); solve(n); return 0; }#include<bits/stdc++.h> using namespace std; void solve(int k){ int i; for(i=40;i>=0;i--) { if(pow(2,i)<=k) { if(i==1)printf("2"); else if(i==0)printf("2(0)"); else { printf("2("); solve(i+1); printf(")"); } k-=pow(2,i); if(k!=0)printf("+"); } } } int main(){ int n; scanf("%d",&n); solve(n); return 0; }