|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
0 f1 q) g/ w* U$ i; v7 h对于三堆棋子的问题有一个通用的解法,如下:
( g: v; F" U7 j7 A3 S; g2 X假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。) h, b4 a! g+ I
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。3 R l! N# Y" ^! a0 C
( \+ @7 B7 [; b3 W v0 @ q/ L7 q如何赢:
$ P6 y4 X: `. \+ Z( t1 \- x如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得% B3 V! j9 F9 s0 t# L
剩下的三堆棋子的个数(a1,b1,c1) 满足
, g& V" f; K, G$ U( x; S8 M3 {a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
% d+ N+ _; {# q, P. K4 A D" S* _7 W& f
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
0 t W! Z& c; r) \0 q总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
2 t5 m( ^0 p) p: R达到三堆全0的状态,那么获胜的必然是先拿的人了。0 n/ V8 }& P" M7 L
: ?$ ]- A5 x X如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
, O# ^' O h5 z: W后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
( J) C# ]6 {! t# j, i
7 D8 a' u" W0 o6 qPS:PM偶个空间^_^ |
|