|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
. `* w6 b, r; T" n I对于三堆棋子的问题有一个通用的解法,如下:
. C2 {* p% F& R- ?假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。! c. Y1 j8 V* Y+ T5 B
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
- Z* G$ g* u, r8 Y: p/ v' _6 d: R9 k" @8 ?0 J' p* e1 G
如何赢:
4 V, p" ]0 e3 J, N5 s4 X如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
0 i# u8 B" r/ p* M: g剩下的三堆棋子的个数(a1,b1,c1) 满足9 e- \3 S5 E- |& C
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
' [2 ^/ r* M! H# c
4 s0 `# Y: a; O+ J. R1 _1 [, X: ~而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
/ r j. U' l& f( Y8 N" @3 u' {总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
6 w) e, R# Q. [) e$ T( J2 v达到三堆全0的状态,那么获胜的必然是先拿的人了。
% O F# O% M, E, |* R8 u
" y7 s7 E( R8 k如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
% y$ ?7 ^" I2 f! o1 S, @; U后拿的人可以在每次拿棋子后满足这个等式,就获胜了。6 r' X' D& j. D; i
3 ?) l/ p$ W6 @
PS:PM偶个空间^_^ |
|