原题链接: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;
}
京公网安备 11010502036488号