|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
* N( V# P7 y8 a! o& @" t对于三堆棋子的问题有一个通用的解法,如下:
! L% C$ A" H) Z6 @/ w假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。# E- g) k w; }) ?8 N
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。4 y% A* O6 T8 p' I/ H
9 q! @4 V7 E- F. d
如何赢:! K6 L: @$ \" F
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
2 p; B9 u4 i( }5 Y5 G( N: ]剩下的三堆棋子的个数(a1,b1,c1) 满足
! K( ]; l7 o* }5 \% u" W) m8 |a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
( t* |5 L* a" t0 D1 k. b7 \/ ?/ j# a) u# Q, n6 n6 \/ \$ c
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
4 i! |, p1 k0 D; @3 \3 j5 H) \" D: v总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
) P g1 S7 V6 [达到三堆全0的状态,那么获胜的必然是先拿的人了。' y) C0 @3 z" |7 i
) G( Z: f7 o8 f4 P! E
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,3 d' @* ]0 q) H5 X' F
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。- G9 Z% y- f. A D7 y- f; z; V$ {! w
0 ]# ^ L5 D/ z4 ~PS:PM偶个空间^_^ |
|