|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
8 K4 m' C( b1 j+ L对于三堆棋子的问题有一个通用的解法,如下:. m6 U0 j8 {: n/ J' _) K
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。 P) m# i2 y' g* _% `; l, [3 W
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
) x' x" \' _& Z; R, q) b' u; ^& w+ M! Q; t5 p
如何赢:7 w+ p" }$ o7 p) Z& c1 w4 h
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
* m+ R& P. R- ^+ F4 I# t ~剩下的三堆棋子的个数(a1,b1,c1) 满足( e6 I! j' i( D: r
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)% p" L: { `, O1 V
! I- p' o2 L9 _' x2 X而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,6 ^% [3 f) [) T
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能. u( g9 F) K' S5 V2 T6 d0 H! H8 Z
达到三堆全0的状态,那么获胜的必然是先拿的人了。
' ~- p( r3 |+ e" }3 ?6 ]/ F( V q# g* I% A, |# F3 V' |
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,; }) ?' x1 r. j. U! J0 K9 X
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
8 ^4 W% T5 w: K3 `% r: Z! A0 M8 J( j8 V3 V/ \5 ^
PS:PM偶个空间^_^ |
|