【问题描述】
给定一个正整数k(3≤k≤15)把所有k的方幂及所有有限个互不相等的k的方幂之和构成一个递增的序列,例如,当k=3时,这个序列是:
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 ,…)
请你求出这个序列的第N项的值(用10进制数表示)。
例如,对于k=3,N=100,正确答案应该是981。
【输入文件】
输入文件sequence.in 只有1行,为2个正整数,用一个空格隔开:
k N
(k、N的含义与上述的问题描述一致,且3≤k≤15,10≤N≤1000)。
【输出文件】
输出文件sequence.out 为计算结果,是一个正整数(在所有的测试数据中,结果均不超过2.1*109)。(整数前不要有空格和其他符号)。
【输入样例】
3 100
【输出样例】
给定一个正整数k(3≤k≤15)把所有k的方幂及所有有限个互不相等的k的方幂之和构成一个递增的序列,例如,当k=3时,这个序列是:
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 ,…)
请你求出这个序列的第N项的值(用10进制数表示)。
例如,对于k=3,N=100,正确答案应该是981。
【输入文件】
输入文件sequence.in 只有1行,为2个正整数,用一个空格隔开:
k N
(k、N的含义与上述的问题描述一致,且3≤k≤15,10≤N≤1000)。
【输出文件】
输出文件sequence.out 为计算结果,是一个正整数(在所有的测试数据中,结果均不超过2.1*109)。(整数前不要有空格和其他符号)。
【输入样例】
3 100
【输出样例】
981
本题思路
其实由于是将有限个互不相等的k,所以我们这里考察第n项的时候,能取到的最大的k的幂次,不妨设次数是p,那么与之相关的很显然应该有2^p个,于是就想到了其实an与k的次数是和n的二进制有关的。 假设n=∑bk*2^k,bk=1或0。于是我们有an=∑(bk*k^(k-1))。 比如说k=3,第7项,因为7对应的二进制数是111(2),所以a7=1*3^2+1*3^1+1*3^0=13。 若为第11项,11对应的二进制是1011(2),所以a11=1*3^3+0*3^2+1*3^1+1*3^0=31
AC代码
#include<stdio.h>
int a[15] = { 1 };
int main(){
int i, k, n;
scanf("%d%d", &k, &n);
for (i = 1; i < 15; i++)
a[i] = a[i - 1] * k;
int t = 0, sum = 0;
while (n){
sum += (n & 0x1) * a[t++];
n >>= 1;
}
printf("%d\n", sum);
return 0;
}
推荐一个公众号,不吐槽,不毒舌,偶尔发发文章,偶尔推荐好物,欢迎关注或者有女票的程序狗们推荐给女票![这里写图片描述](https://img-blog.csdn.net/201805082344360?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTMxNzQ3MDI=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70)