首页 > 其他 > 详细

2020.3.18 Luogu1010 幂次方

时间:2020-03-18 23:55:26      阅读:102      评论:0      收藏:0      [点我收藏+]

递归+二进制
注意判断1

代码:

#include <iostream>
#include <cstdio>

using namespace std;

int n;

inline string div(int x)
{
    if (x == 0)
        return "0";
    if (x == 1)
        return "2(0)";
    if (x == 2)
        return "2";
    int p[20], q = x, id = 0;
    while (q != 1)
    {
        p[id++] = q % 2;
        q /= 2;
    }
    p[id++] = 1;
    string ret;
    if (id - 1 == 1)
        ret = "2";
    else
        ret = "2(" + div(id - 1) + ")";
    for (int i = id - 2; i >= 0; --i)
    {
        if (p[i] == 1 && i != 1)
            ret += "+2(" + div(i) + ")";
        if (p[i] == 1 && i == 1)
            ret += "+2";
    }
    return ret; 
}

int main()
{
    cin >> n;
    cout << div(n) << endl;
    return 0;
}

2020.3.18 Luogu1010 幂次方

原文:https://www.cnblogs.com/pipa-peng/p/12520833.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!