Acwing 428

可以找到规律,将第 N 项的 N 对应的二进制表示,转换为以 k 为基底的数即可。
N=1=1 —-> 1 —-> (a^b)
N=2=2 —-> 10 —-> (3^1)
N=3=3 —-> 11 —-> (3^0)+(3^1)
N=4=4 —-> 100 —-> (3^2)
N=5=5 —-> 101 —-> (3^2)+(3^0)
N=6=6 —-> 110 —-> (3^1)+3 (^2)
N=7=7 —-> 111 —-> (3^0)+(3^1)+(3^2)

代码

#include <iostream>

using namespace std;

int main()
{
    int k, n;
    cin >> k >> n;
    int res = 0, base = 1;
    while (n)
    {
        res += n % 2 * base;
        base *= k;
        n /= 2;
    }
    cout << res << endl;
    return 0;
}
</iostream>

Original: https://www.cnblogs.com/Holdpark/p/16211076.html
Author: 似是笼中雀
Title: Acwing 428

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/604237/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球