#P0997. [NOIP2006普及组] 数列

题目描述

给定一个正整数k(3≤k≤15)k(3≤k≤15),把所有k的方幂及所有有限个互不相等的k的方幂之和构成一个递增的序列,例如,当k=3k=3时,这个序列是:

1,3,4,9,10,12,13,...1,3,4,9,10,12,13,...

(该序列实际上就是:3^0,3^1,3^0+3^1,3^2,3^0+3^2,3^1+3^2,3^0+3^1+3^2,...30,31,30+31,32,30+32,31+32,30+31+32,...)

请你求出这个序列的第NN项的值(用1010进制数表示)。

例如,对于k=3k=3,N=100N=100,正确答案应该是981981。

输入格式

22个正整数,用一个空格隔开:

k NkN (kk、NN的含义与上述的问题描述一致,且3≤k≤15,10≤N≤10003≤k≤15,10≤N≤1000)。

输出格式

11个正整数。(整数前不要有空格和其他符号)。

输入数据 1

复制代码
3 100

Copy

输出数据 1

复制代码
981

Copy

来源

NOIP 2006 普及组 第四题

代码:

cpp 复制代码
#include <iostream>
#include <cmath>
using namespace std;

/**
 * 判断 x 是不是 2 的 k(k为正整数)次方
 */
bool judgePow2(int x)
{
    int y = log(x) / log(2);
    int result = pow(2,y);
    return result == x;
}

/**
 * 递归
 */
int add(int n, int k)
{
    if(n==1) return 1;
    if(n==2) return k;
    if(judgePow2(n) == true) {
        int p = log(n)/log(2);
        int result = pow(k,p);
        return result;
    }
    int temp = log(n)/log(2);
    int base = pow(k,temp);
    int temp2 = pow(2,temp);
    return base + add(n-temp2,k);
}

int main()
{
    int m,n;
    cin>>m;
    cin>>n;
    cout<<add(n,m)<<endl;
    return 0;
}
相关推荐
艾莉丝努力练剑12 分钟前
【C语言16天强化训练】从基础入门到进阶:Day 6
c语言·数据结构·学习·算法
快去睡觉~1 小时前
力扣1005:k次取反后最大化的数组和
数据结构·算法·leetcode
smilejingwei1 小时前
数据分析编程第二步: 最简单的数据分析尝试
数据库·算法·数据分析·esprocspl
草莓熊Lotso2 小时前
【C语言强化训练16天】--从基础到进阶的蜕变之旅:Day10
c语言·开发语言·经验分享·算法·强化
张同学的IT技术日记2 小时前
详细实例说明+典型案例实现 对迭代法进行全面分析 | C++
算法
Coovally AI模型快速验证2 小时前
全景式综述|多模态目标跟踪全面解析:方法、数据、挑战与未来
人工智能·深度学习·算法·机器学习·计算机视觉·目标跟踪·无人机
risc-v@cn3 小时前
【在ubuntu下使用vscode打开c++的make项目及编译调试】
c++·vscode·ubuntu
让我们一起加油好吗3 小时前
【C++】多态(详解)
c++·visualstudio·多态·虚函数
草莓熊Lotso3 小时前
【C++】--函数参数传递:传值与传引用的深度解析
c语言·开发语言·c++·其他·算法
不知名。。。。。。。。3 小时前
算法 ----- 链式
算法