#P20083. [NOIP2006 提高] 2^k进制数
[NOIP2006 提高] 2^k进制数
题目描述
设是个 进制数,并满足以下条件:
(1)r至少是个位的 进制数。
(2)作为 进制数,除最后一位外,的每一位严格小于它右边相邻的那一位。
(3)将转换为进制数后,则的总位数不超过。
在这里,正整数和$w(k
问:满足上述条件的不同的r共有多少个?
我们再从另一角度作些解释:设是长度为 的字符串(即字符串由个“”或“”组成),对应于上述条件()中的。将从右起划分为若干个长度为的段,每段对应一位进制的数,如果至少可分成段,则S所对应的二进制数又可以转换为上述的进制数。
例:设。则是个八进制数()。由于,长度为的字符串按位一段分,可分为段(即,左边第一段只有一个二进制位),则满足条件的八进制数有:
位数:
高位为:个(即),
高位为:个,
…,
高位为:个(即)。
共个。
位数:
高位只能是,
第位为:个(即),
第位为:个,
…,
第位为:个(即)。
共个。
所以,满足要求的共有个。
输入格式
个正整数,用一个空格隔开:
输出格式
个正整数,为所求的计算结果,即满足条件的不同的的个数(用十进制数表示),要求最高位不得为,各数字之间不得插入数字以外的其他字符(例如空格、换行符、逗号等)。
(提示:作为结果的正整数可能很大,但不会超过位)
样例
3 7
36
说明
NOIP 2006 提高组 第四题