题目描述
甲乙两个人玩取石子游戏。他们面前有一堆共 个石子,然后由甲先手,两人轮流从中取走石子:甲第一次取走的个数不能超过 ,接下来每个人取走的个数不能超过上一个人刚刚取走个数的 倍。每人每次必须至少取一个石子。取走最后一个石子的人失败,另一方获胜。现在已知 ,请你求出在 到 中有多少整数 使得甲在 颗石子的游戏中有必胜策略。
输入格式
多组数据。
第一行一个正整数 表示数据组数。
接下来 行每行两个用空格隔开的整数 ,表示一组询问。
输出格式
输出 行,按照输入顺序,每行一个整数表示答案。
输入输出样例 #1
输入 #1
输出 #1
说明/提示
样例说明
对于样例 ,当 时:
- 如果 ,甲只能取走唯一一颗石子从而失败。
- 如果 ,甲取走一颗石子,乙只能取走最后一颗石子,甲获胜。
- 如果 ,甲只能取走一颗石子,乙再取走一颗石子,甲只能取走最后一颗石子从而失败。
- 如果 ,甲只能取走一颗石子,乙再取走两颗石子,甲只能取走最后一颗石子从而失败。
- 如果 ,甲只能取走一颗石子,乙只能取走一颗或两颗石子,甲总能再留给乙留下最后一颗石子从而获胜。
数据说明与提示
对于所有数据,。
- 对于 的数据,。
- 对于另外 的数据,。
- 对于另外 的数据,。
- 对于另外 的数据,。
- 对于余下 的数据,无特殊限制。
题解
取到最后一颗石子的输,可以直接认为是取到倒数第二颗石子的获胜。
令 表示还剩 颗石子,本次最多能取 颗石子时是否是先手必胜。由策梅洛定理,
容易发现,对于某一个特定的 ,必然有一个 ,使得对于所有的 都有 。
设 表示最小的 使得 ,那么一定有 。这一不等式的含义是,局面 下取走 个石子后,下一个局面 必胜所需要取走的数目 必然大于 ,否则 不是一个必胜局面。
容易发现,这个数列的生成方式与斐波那契数列有关。设 表示斐波那契数列的第 项, 的前 项就是将前 项接在第 项后面,然后将第 项替换成 。换言之, 等于 在斐波那契进制下的 lowbit。
现在要求的答案是 ,因为 内本质不同的数字个数只有 个,所以可以分别统计出现次数。
设 表示前 项中 的出现次数,那么 可以 预处理,之后用类似斐波那契进制的就可以 地回答询问了。使用简单的前缀和优化可达到 的总复杂度。