博弈论之巴什博奕

巴什博弈(定理):

  只有一堆n个物品,两个人轮流从这堆物品中取物, 规定每次至少取一个,最多取m个。最后取光者得胜。

  如果n=m+1,一次最多只能取m个,无论先取者拿走多少个,后取者都能够一次拿走剩余的物品,则后者取胜。

  取胜的法则 :如果 n=(m+1)r+s,(r为任意自然数,s≤m),那么先取者要拿走s个物品,如果后取者拿k(k≤m)个,那么先取者再拿走m+1-k个,结果剩下(m+1)(r-1)个,以后保持这样的局势,那么先取者必然获胜。

n%(m+1) != 0总之,要保持留给对手(m+1)的倍数个物品这样的局势,先取者最后就能获胜。

相关题目有 HDU-1846、HDU-1847、HDU-2147、HDU-2149、HDU-2188

相关代码 :

 

 1 #include <iostream>
 2 
 3 using namespace std;
 4 
 5 
 6 int main()
 7 {
 8     int n,m;
 9     while(cin>>n>>m)
10       if(0 == n%(m+1)) 
11            cout<<"后手必胜"<<endl;
12       else 
13            cout<<"先手必胜"<<endl;
14 return 0;
15 }

 

posted @ 2016-08-19 12:12  jb-simple  阅读(393)  评论(0编辑  收藏  举报