|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
, O" w- L F# Z6 j对于三堆棋子的问题有一个通用的解法,如下:
; }4 E4 }5 c+ ^0 a% E假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
9 {. C6 P' c6 L5 u( n/ T如果a^b^c=0,则后拿的赢,反之,则先拿的赢。3 o! B$ c0 M. S) W7 @( [- `
3 ?' F: s: K f" \3 Z如何赢:% c+ X0 H9 r/ d. L4 A3 K' P
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得/ V" F! N. {% ]/ Y
剩下的三堆棋子的个数(a1,b1,c1) 满足
& V+ F9 n$ j3 qa1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个). y5 I: I3 [/ g" [/ P( @
) X# E7 C6 W2 u4 j而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
' h4 O) d3 ]# D2 w总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
% I" C. p( `& K- z+ {/ A: i达到三堆全0的状态,那么获胜的必然是先拿的人了。
8 R) H# }" R. L
- k& X/ V E s如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
/ A, e* _3 k: O) z/ D后拿的人可以在每次拿棋子后满足这个等式,就获胜了。8 ], R+ g H# A0 }% g# z* G1 V
9 A$ @, r, y# V0 GPS:PM偶个空间^_^ |
|