NOIP2006普及 数列(sequence)

博客介绍了NOIP2006竞赛中的一个数列问题,要求求出一个特定序列的第N项。这个问题可以通过模拟和进制转换的方法解决。博主给出了90分的常规解法,使用两个指针处理K的方幂和的组合,并提出了100分的骚操作,即通过将数列转换为2进制再转为K进制来找到答案。样例输入为k=3, N=100,输出为981。" 113081932,10546991,Java跳出多层循环技巧,"['Java', '循环控制', '编程技巧']
摘要由CSDN通过智能技术生成

考试第二题,这道题存在很多骚操作。我是用了一种类似模拟的方法,听说有转进制超简单方法……
题目:给定一个正整数k(3≤k≤15),把所有k的方幂及所有有限个互不相等的k的方幂之和构成一个递增的序列,例如,当k=3时,这个序列是:
1,3,4,9,10,12,13,…
(该序列实际上就是:30,31,30+31,32,30+32,31+32,30+31+32,…)
请你求出这个序列的第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*10^9)。(整数前不要有空格和其他符号)。

样例输入
3 100

样例输出
981
简介就不给了,NOIP的好题目!
主要方法(90分):
1.首先我们要知道这个数列上的所有数都是K的倍数,而这时我们还要想到——因为还可以加上0次方也就是1,所以有两种数(一种原数×k+1,另一种不+1)。
2.我们要定义两个指针,具体用处看code。
好了,到了code时间:

#include<cstdio>
using namespace std;
long long k,n,f[1005];
void putin()//输入(感觉这样缩短主程序真香)
{
   
	f[1]=1</
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值