首页 > 其他 > 详细

阶梯博弈(历届试题 高僧斗法 )

时间:2015-03-26 12:22:50      阅读:190      评论:0      收藏:0      [点我收藏+]
转载的:
今天在POJ做了一道博弈题..进而了解到了阶梯博弈...下面阐述一下我对于阶梯博弈的理解..
 首先是对阶梯博弈的阐述...博弈在一列阶梯上进行...每个阶梯上放着自然数个点..两个人进行阶梯博弈...每一步则是将一个集体上的若干个点( >=1 )移到前面去..最后没有点可以移动的人输..
技术分享
如这就是一个阶梯博弈的初始状态 2 1 3 2 4 ... 只能把后面的点往前面放...如何来分析这个问题呢...其实阶梯博弈经过转换可以变为Nim..把所有奇数阶梯看成N堆石子..做nim..把石子从奇数堆移动到偶数堆可以理解为拿走石子..就相当于几个奇数堆的石子在做Nim..( 如所给样例..2^3^4=5 不为零所以先手必败)为什么可以这样来转化?
   假设我们是先手...所给的阶梯石子状态的奇数堆做Nim先手能必胜...我就按照能赢的步骤将奇数堆的石子移动到偶数堆...如果对手也是移动奇数堆..我们继续移动奇数堆..如果对手将偶数堆的石子移动到了奇数堆..那么我们紧接着将对手所移动的这么多石子从那个偶数堆移动到下面的奇数堆...两次操作后...相当于偶数堆的石子向下移动了几个..而奇数堆依然是原来的样子...即为必胜的状态...就算后手一直在移动偶数堆的石子到奇数堆..我们就一直跟着他将石子继续往下移..保持奇数堆不变...如此做下去..我可以跟着后手把偶数堆的石子移动到0..然后你就不能移动这些石子了...所以整个过程..将偶数堆移动到奇数堆不会影响奇数堆做Nim博弈的过程..整个过程可以抽象为奇数堆的Nim博弈...
   其他的情况...先手必输的...类似推理...只要判断奇数堆做Nim博弈的情况即可...
   为什么是只对奇数堆做Nim就可以...而不是偶数堆呢?...因为如果是对偶数堆做Nim...对手移动奇数堆的石子到偶数堆..我们跟着移动这些石子到下一个奇数堆...那么最后是对手把这些石子移动到了0..我们不能继续跟着移动...就只能去破坏原有的Nim而导致胜负关系的不确定...所以只要对奇数堆做Nim判断即可知道胜负情况...、
 
 
自己的:

技术分享

技术分享

 

这个游戏可以转化为Nim游戏,石子堆所有 为排奇数位置的人与它后面一个排偶数位置人的距离

如果,石子堆为  a与b之间的距离1,c与d之间的距离1,   1^1=0,所以先手必败

如图,无论排偶数位置的人怎么移动,排在它前面位置的人都能够跟着移动,但是排奇数位置的人移动,偶数位置的人就不能跟着移动

比如b向上移动一个台阶,那么a也能够向上一个台阶。那么总的局面还是 1^1.

 1 #include <stdio.h>
 2 #include <string.h>
 3 const int N = 100 + 10;
 4 int a[N],b[N];
 5 int main()
 6 {
 7     int n = 0,i,j,k,sum = 0;
 8     while(scanf("%d",&a[n])!=EOF)
 9         n++;
10     for(i=1; i<n; ++i)
11         b[i-1] = a[i] - a[i-1] - 1;
12     for(i=0; i<n-1; i+=2)
13         sum ^= b[i];
14     if(sum==0)
15         printf("-1\n");
16     else
17     {
18         //枚举第i个人移动j步,使得剩下的局面异或等于0,
19         for(i=0; i<n-1; ++i)
20             for(j=1; a[i]+j<a[i+1]; ++j)
21             {
22                 
23                 b[i] -= j;
24                 if(i!=0)
25                     b[i-1] += j;
26                 
27                 sum = 0;
28                 for(k=0; k<n-1; k+=2)
29                     sum ^= b[k];
30                 if(sum==0)
31                 {
32                     printf("%d %d\n",a[i],a[i]+j);
33                     break;
34                 }
35                 b[i] += j;
36                 if(i!=0)
37                     b[i-1] -= j;
38                 
39             }
40     }
41     return 0;
42 }

 

  

阶梯博弈(历届试题 高僧斗法 )

原文:http://www.cnblogs.com/justPassBy/p/4367904.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!