题目:
熊孩子的乐趣
时间限制: 1000ms 内存限制: 65535KB
通过次数: 8 总提交次数: 12
Alice跟Bob是学校里出了名的两个熊孩子,会在任何事情上争个高低,彼此都不服输。幼儿园的老师每次分糖果的时候看到这两个熊孩子也很头疼,两个人都想占便宜,争个你胜我负,老师还要想办法来安慰输了的一方。
老师每次会拿n个糖果来分给Alice跟Bob,老师规定了每人每次最多只能在盘子里拿走m个糖果(小朋友每次至少都要拿一个),由于Alice是女孩子,所以每次由Alice先从盘子里拿,然后是Bob。Alice跟Bob数学不好,他们并不知道拿的多的人是占便宜的一方,他们认为拿走最后一个糖果的人是胜利者,这样可以扮鬼脸来嘲对方。
老师这可发愁了,他不知道每天分糖果的时候Alice跟Bob谁胜谁负,总得有个准备去安慰下哭鼻子的那个。老师希望你可以帮帮他,提前算出每次分糖果谁会赢。(假设Alice跟Bob每次决定拿走糖果数量的目的都是为了让自己可以成功拿走最后一个,成为最后的赢家)。
第一行输入一个T,表示有T组测试数据。
对于每组测试数据,包含两个正整数n,m。(1<=n,m<=1000000000)
先手:Alice
后手:Bob
输出一行 Alice OR Bob
2 15 3 100 24
Alice Bob
思路:博弈论水题。
截取有关本题部分:
巴什博弈
1、问题模型:只有一堆n个物品,两个人轮流从这堆物品中取物,规定每次至少取一个,最多取m个,最后取光者得胜。
2、解决思路:当n=m+1时,由于一次最多只能取m个,所以无论先取者拿走多少个,后取者都能够一次拿走剩余的物品,后者取胜,所以当一方面对的局势是n%(m+1)=0时,其面临的是必败的局势。所以当n=(m+1)*r+s,(r为任意自然数,s≤m)时,如果先取者要拿走s个物品,如果后取者拿走x(≤m)个,那么先取者再拿走m+1-k个,结果剩下(m+1)(r-1)个,以后保持这样的取法,那么先取者肯定获胜。总之,要保持给对手留下(m+1)的倍数,就能最后获胜。
3、变形:条件不变,改为最后取光的人输。
结论:当(n-1)%(m+1)==0时后手胜利。
#include<bits/stdc++.h> typedef long long ll; using namespace std; int main(){ ios::sync_with_stdio(false); int t; cin>>t; while (t--){ int n,m; cin>>n>>m; if( n%(m+1) == 0){ printf("Bob\n"); } else printf("Alice\n"); } return 0; }