|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。" W' H* A) g9 |/ x* A9 j" T' y, d
对于三堆棋子的问题有一个通用的解法,如下:
" b O# m1 [( p6 R# c假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
w8 ^" D: J; Q1 k0 Y如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
- o% p1 ^5 p& d* h5 E/ s5 N# l, h: I- h* R" q/ a
如何赢:( f F E( F' ^
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得* |9 b8 i2 f) g" B, N, m; D
剩下的三堆棋子的个数(a1,b1,c1) 满足
' g3 l: D5 q1 t% la1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)# c4 T* \/ U3 @1 y* K
$ ~: a* Z* A" m
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,( w6 ^5 Z! U: O6 X
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能' G3 s; Z& b, u+ z+ H4 Y$ [
达到三堆全0的状态,那么获胜的必然是先拿的人了。% P& {3 n5 s3 Y( }. J+ J) ^
- }# {' |; s5 r$ s" K+ ?
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,7 Y' j2 N: o) X! P$ }$ R/ K: l
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
/ P. o& W, S4 Z, d E- Z8 p ~ d# Q3 n3 B/ e' t! d4 D
PS:PM偶个空间^_^ |
|