|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
7 o9 M. ^" A( @; ?! D$ ?对于三堆棋子的问题有一个通用的解法,如下:$ V7 S% ~ [/ ?" k
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
' e) l- a V0 A如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
2 d. I+ s; b. [! C# q, x+ g0 u+ _! ], a# j) m1 x
如何赢:
: g8 K6 B { _$ l+ V6 @9 f如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
. u1 u R, z) @! z' w8 C' B剩下的三堆棋子的个数(a1,b1,c1) 满足 K6 r: X/ e6 q* ]# w3 A2 v
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)- k! ^' E1 U3 c) s2 a& Q3 H" Z- z
- G# B9 V* C! F1 i5 D+ G" d, I
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,$ B7 w) B( W! ?6 ]* ~7 }0 }9 j
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
3 p* ?* r; Y9 P0 o4 k0 y达到三堆全0的状态,那么获胜的必然是先拿的人了。5 P$ V& T. {) I8 R$ H% F/ C
) Q# b; F9 o9 P0 Q- t
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
+ R$ [$ o- } P+ D$ w后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
' v: e/ h! b& g" R2 t- S% \. b1 \8 q! n5 W1 |
PS:PM偶个空间^_^ |
|