|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
+ ^8 b9 }+ V% G9 S" l对于三堆棋子的问题有一个通用的解法,如下:2 q+ {: Y4 Q' b' ~
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
0 p! o8 ^, s- m* z6 g0 }; f3 r3 q如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
, Z. q$ E* a& b! Q+ B% W. F5 S' K& L4 d6 V; W$ s
如何赢:# f, N1 T2 q u% L
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
7 i1 a( [" _+ d剩下的三堆棋子的个数(a1,b1,c1) 满足
5 l6 G' d: d/ ]a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)3 K& d4 \/ b- L7 u8 N4 M" l( ]. X
% Q$ w8 z/ O; K K6 K% q
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,. H K6 h+ |' T9 a+ [
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能 S/ x4 p/ x5 ~% |5 s' F6 `& U
达到三堆全0的状态,那么获胜的必然是先拿的人了。6 m* B; \/ A; x8 x2 S
" [9 T5 A! |& h# @3 }8 d- x如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,: S6 d$ [% r5 W* f/ r6 f& F
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。# B) N0 j6 a( n5 l
9 Y/ w- n# w' i b$ m! P
PS:PM偶个空间^_^ |
|