#CF2184D. Unfair Game
Unfair Game
题目描述
Bob 厌倦了输给 Alice,为了保证自己不会再输,决定选择一个能确保自己获胜的游戏。Bob 从 到 中选了一个数,其中 , 是某个非负整数。起初,Alice 知道所选数字是否为偶数。
每一回合,Alice 可以选择将当前数字减半(只有当当前数字为偶数时可以执行),或者将当前数字减去 。每次只有 Alice 执行操作。
操作后,Alice 会收到 Bob 的回复:要么是 ,表示数字变为 ,Alice 获胜;要么是一个非负整数 。如果当前的数字为 ,则 满足以下条件:
- 能被 整除。
- 不能被 整除。
例如,若 ,则 ,因为 能被 整除但不能被 整除;若 ,则 ,因为 能被 整除但不能被 整除。
可以证明,对于任意 ,这样的 存在且唯一。
Bob 仍然担心 Alice 会获胜,因此游戏最多只能进行 步。此外,Bob 想让自己尽可能多地赢,所以他希望游戏数尽量多。给定 和 ,请计算使得 Alice 无法在不超过 步内必胜的初始数的数量(即在 到 中,有多少个数 Alice 最优策略下无法在 步内赢得游戏)。
输入格式
第一行包含一个整数 ,表示测试用例数量,。
每个测试用例包含一行,包含两个整数 和 ,,, 为某个非负整数。
输出格式
对于每个测试用例,输出一行一个整数,表示对于 到 ,Alice 最优情况下无法在最多 步内赢的初始数的数量。
样例
7
4 1
4 2
4 3
4 4
4 5
16 5
16 1
3
2
0
0
0
4
15
样例说明
在第一个样例中,、、 满足条件,因为从 一步可以变成 ,而对其它值可以证明最少需要 步才行。
在第二个样例中, 和 符合条件,因为对 ,Alice 可以通过 步获胜。
在第三、四、五个样例中,没有符合条件的 ,因为对于 和 ,Alice 至多三步内都能取胜。
由 ChatGPT 5 翻译
来源
Codeforces 2184D,英文题名 Unfair Game。