|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。! x# y0 n4 j& b
对于三堆棋子的问题有一个通用的解法,如下:/ a2 w$ ~$ y! C, c0 V
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
8 w! {0 A$ r* A& i0 `8 B: q) U如果a^b^c=0,则后拿的赢,反之,则先拿的赢。0 F p; }1 d W- d
. @1 E3 ]/ C a# ]
如何赢:
% O' x6 O* O- Y如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得& j5 c* h! D) B h* }2 X# `
剩下的三堆棋子的个数(a1,b1,c1) 满足
+ F* Y/ p) n. Q5 z9 Wa1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)/ s1 } ]/ x& b5 L! l6 N
; P. r; Q3 g% g2 Q" @3 n7 }而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
: D3 ?4 E% x! I! p+ \ s8 o- J总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能4 B4 \; a) x5 y& `
达到三堆全0的状态,那么获胜的必然是先拿的人了。
% a, m- J0 e+ p4 _% k7 W7 Y2 t% e' @- }# G+ e, e% R
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,! a: Z8 u4 j: L9 b1 E
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。, i' c d7 s$ r" a4 q
; I+ `% w1 j7 f9 s0 o9 N# w1 _PS:PM偶个空间^_^ |
|