|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
( P; O- R3 K* p对于三堆棋子的问题有一个通用的解法,如下:
* h; w+ q+ B5 Z# \* U z4 n假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
( r- v; n# Z- U- V" ~0 s如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
1 [; Y- T) g% `1 ^
- m8 v& ?2 }6 \- r如何赢:
1 Z0 K2 |1 K9 V9 i$ d- \% G% i如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
# Z: a- w4 E1 z0 M剩下的三堆棋子的个数(a1,b1,c1) 满足& n. Z; o8 s: k" @1 w
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
~" |/ A8 h' @5 b& E
. b; ^! @) f) I而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,* E' y& b" A7 X- F: V
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能) s2 e7 ~ j8 I6 a( Y8 B
达到三堆全0的状态,那么获胜的必然是先拿的人了。
6 c" y/ g5 P1 S+ _) w# k. {! T$ B5 ^, x4 j- W; N
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,8 l: g$ _4 j9 u* @. i8 E+ h
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
% q, C- q6 u5 h* J4 l9 b
4 z1 h0 [% k9 p* J2 `. Q7 UPS:PM偶个空间^_^ |
|