题解 | #2的幂次方#

2的幂次方

https://www.nowcoder.com/practice/7cf7b0706d7e4b439481f53e5fdac6e7

#include <iostream>
using namespace std;

string dfs(int n){
    string res;
    for(int i=14;i>=0;i--){
        if(n>>i&1){
            if(res.size()) res+="+";
            if(i==0) res+="2(0)";
            else if(i==1) res+="2";
            else res+="2("+dfs(i)+")";
        }
    }
    return res;
}

int main() {
    int n;
    while (cin>>n) { // 注意 while 处理多个 case
       cout<<dfs(n)<<endl;
    }
    return 0;
}

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务