原题链接:https://ac.nowcoder.com/acm/contest/19305/1019
题目描述
给定一个正整数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。
输入描述:
输入1行,为2个正整数,用一个空格隔开:k N(k、N的含义与上述的问题描述一致,且3 ≤ k ≤ 15,10 ≤ N ≤ 1000 )。
输出描述:
输出一个正整数。(整数前不要有空格和其他符号)。
示例1
输入
3 100
输出
981
观察序列的结构特点,可以发现和二进制进位非常相似
k的指数代表二进制第几位,有无代表二进制的0和1
如题目中第5个序列3^0+3^2代表5的二进制数101(1*3^0+0*3^1+1*3^2)
只要将N转化为二进制数,每次把第i位编号为i并取出即可,然后累加a[i](int)pow(k1.0,i*1.0)
#include <stdio.h> #include <iostream> #include <cmath> using namespace std; int main() { int k,N,i=0,ans=0; scanf("%d %d",&k,&N); int a[30]; while(N!=0) { a[i]=N&1; N >>= 1; i++; } while(i>=0) { i--; ans+=a[i]*(int)pow(k*1.0,i*1.0); } cout << ans <<endl; return 0; }
可以把++塞到数组里面 简化一下
#include <iostream> #include <cstring> #include <algorithm> #include<bitset> using namespace std; const int N= 100; bitset<N> a; int main() { int k,n; cin >> k >> n; int i = 0; while(n) { if(n&1) a[i++] = 1; else a[i++] = 0; n >>= 1; } return 0; }