NOIP2006数列

【问题描述】
给定一个正整数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)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值