|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
: | R5 g% s( Y* a: q( N对于三堆棋子的问题有一个通用的解法,如下:+ b/ Z; l8 a# L2 i# q8 Y( _& ~
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。0 I- u& U; O1 N. q
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。0 o/ ?. r5 y& _
6 g& q. z8 ?6 N" l# j8 d如何赢:: Z2 F6 O& y9 |$ p: T1 z
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
, N7 D6 t* j* b. L$ @剩下的三堆棋子的个数(a1,b1,c1) 满足
7 D y) l+ Y' n! X4 t; k% i8 ]7 Ya1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个), V1 D+ G6 ?! d+ m8 q
! w1 |. k: t3 _1 F% g+ K
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,% P2 [% M8 v" ~3 h, s/ t
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能$ G2 [3 B( ?! j6 i
达到三堆全0的状态,那么获胜的必然是先拿的人了。
p" Y, S$ u' x
6 t6 Y& I- d' g. p. r1 d$ D如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
! k4 L* L7 K* R后拿的人可以在每次拿棋子后满足这个等式,就获胜了。. V- i" p, a: B+ i, c
/ C: r; e. C% A" u% {( y, W/ |& T
PS:PM偶个空间^_^ |
|