中北大学NUC2017新生赛1001/NOJ-1981

题目:

熊孩子的乐趣

时间限制: 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



思路:博弈论水题。

常见acm博弈论:(来自ac-data点击打开链接

截取有关本题部分:

巴什博弈

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;
}



  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值