|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。3 @/ @4 C& Q( q7 G
对于三堆棋子的问题有一个通用的解法,如下:5 t3 X: T/ X. e3 |5 r5 P* m9 Q8 o
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
8 x/ \; j+ H8 Y5 C, q; W# ]3 V% n& ~2 C+ {如果a^b^c=0,则后拿的赢,反之,则先拿的赢。$ N2 H' X" C% C; u4 Q% r
, i8 U1 H9 ?1 e如何赢:, t3 |) s* B8 i! T: Z* }" g
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得' ^3 M% ?( u5 e9 Z1 g
剩下的三堆棋子的个数(a1,b1,c1) 满足
9 G$ U- x" Z1 _) a4 s" `a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)# t, ], P2 V- b4 Q
: K6 D- n4 b+ {( h1 o) J
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
; _0 U# X& c8 U" h2 `总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能6 [ W) O9 Y4 @
达到三堆全0的状态,那么获胜的必然是先拿的人了。, S4 k4 X, _$ @/ |5 r( G1 _5 E
% ]* i) `) C0 [, |0 z$ C如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
0 T) v9 |( \4 u后拿的人可以在每次拿棋子后满足这个等式,就获胜了。% U$ V: P6 H/ m
5 v- R/ F8 ~ _/ ?+ r h
PS:PM偶个空间^_^ |
|