巴什博弈的理解

巴什博弈一般题目描述:只有一堆n个物品,两个人轮流从这堆物品中取物,规定每次至少取一个,最多取m个。最后取光者得胜。

理解:显然,如果n=m+1,那么由于一次最多只能取m个,所以,无论先取者拿走多少个,后取者都能够一次拿走剩余的物品,后者取胜。因此我们发现了如何取胜的法则:如果n=(m+1)r+s,(r为任意自然数,s≤m),那么先取者要拿走s个物品,如果后取者拿走k(≤m)个,那么先取者再拿走m+1-k个,结果剩下(m+1)(r-1)个,以后保持这样的取法,那么先取者肯定获胜。总之,要保持给对手留下 (m+1)的倍数,就能最后获胜。

#include<stdio.h>
int main(){
	int n,m;//n是石头的个数,m是每次最多取石头的个数
	
	while(~scanf("%d%d",&n,&m)){
		if(n%(m+1) == 0)
			printf("后者胜\n");
		else
			printf("前者胜\n");
	}
	return 0;
}

对于巴什博弈,还有个玩法,如果我们规定,如果最后取光者输,那么又会如何呢?
可以这样想:获胜者一定取了第n-1个石头,那么就可以这样想:谁先取了第n-1个石头谁就是胜利者,代码仅有一点改动:

#include<stdio.h>
int main(){
	int n,m;//n是石头的个数,m是每次最多取石头的个数
	
	while(~scanf("%d%d",&n,&m)){
		if((n-1)%(m+1) == 0)
			printf("后者胜\n");
		else
			printf("前者胜\n");
	}
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值