|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。. w \7 b0 `# T' `$ Z, V; V
对于三堆棋子的问题有一个通用的解法,如下:7 ]& X' Y1 L( e: \6 Q; z1 U3 O
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
6 l1 q. u' I* g如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
5 b1 w9 k& K! d K0 Q/ V, Y- d; |: V/ A5 i
如何赢:
/ {9 u& ]+ _4 g/ m$ J3 q如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得9 S( S3 x$ b8 u( Y# [* }
剩下的三堆棋子的个数(a1,b1,c1) 满足8 Q, F+ u) i# G# i1 a
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)/ \4 }! r* s/ I2 k1 u* f) N0 D
4 @- ~( Y4 c' y$ q而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,4 |1 h0 r# w5 P$ V( v
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能" |' R- s% ]! J0 P; ]3 a
达到三堆全0的状态,那么获胜的必然是先拿的人了。
* U f0 a$ P7 J
/ c5 M3 x: X/ M+ B如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,9 C8 m9 J; P. m* k( K3 A5 l
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
, \+ F$ X4 c" a. A7 Z, f5 t" A$ a# _ S6 Q
PS:PM偶个空间^_^ |
|