|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。. R0 u$ B6 Q6 z9 c5 Q$ R
对于三堆棋子的问题有一个通用的解法,如下:7 l6 m1 q7 I( w7 l; I" s
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。, Z& B& F7 Y8 j d O( s/ v% Y) q# s
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。6 S c# M- u0 r2 Y
: u l( B! u4 ?8 _0 F* }" ^如何赢:+ t- e$ G" O2 X- C* y
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得* r( {/ R' U( X5 Y! m
剩下的三堆棋子的个数(a1,b1,c1) 满足/ G+ I. ?. D% B! J* C, Z+ ]! C
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)0 v) [ U; c5 P7 u. I' I8 a
! e3 N( {8 j' O2 y而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
& J& p( A8 n2 _$ a/ N$ m总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
( m7 {; b1 I: n7 S: e3 u0 G达到三堆全0的状态,那么获胜的必然是先拿的人了。0 Q3 M4 A0 U2 f8 ]& d
6 A7 G' K' ~. C6 f) q+ F
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式," C+ u7 R, [( x" j- G$ l7 [: X
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。5 H, m! j4 J5 ]& V, _* v
2 i6 g! z9 }, u) V* U/ J1 x9 J3 ~PS:PM偶个空间^_^ |
|