|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。2 l" D% O- u8 a5 _" O2 ^* r3 k4 ]1 b+ O
对于三堆棋子的问题有一个通用的解法,如下:
. w* E# d T- |3 K6 c8 X假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。% I' N1 y$ A- u( l
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
) C5 z8 ?; C% k9 [$ p; z4 z7 U4 h: f8 G8 \
如何赢:% V+ l7 R: o% z
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
$ ^' j9 M" z0 G* h剩下的三堆棋子的个数(a1,b1,c1) 满足
* K8 o3 ]& H7 T: S' Z u. S% e* ia1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)6 U5 E2 W5 j% u/ \, M" e
) i& F& i; N2 Y5 g" A
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
: O) M$ O* Y! p$ F( h总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能: i+ ^" [7 y) a$ L% j0 j3 j% u
达到三堆全0的状态,那么获胜的必然是先拿的人了。8 X9 O2 Q2 Y) H% L
6 K( E5 P3 E# n1 S
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
/ ?, n# H6 S% F0 r+ ^后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
' a1 R3 n1 ~9 x+ a1 x1 f7 x
# _ A% x- K+ H3 B, t5 h3 fPS:PM偶个空间^_^ |
|