|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
% S& Y, C/ R/ u对于三堆棋子的问题有一个通用的解法,如下: V( C( a7 G f% H8 {
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
: ?5 u, q7 p2 }3 ~; z如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
5 d7 v7 A1 h( P& x5 u4 u
5 X% A( f5 E: _7 S7 Y如何赢:
4 _! W% V# A# V如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得. X8 M) Y) I& O4 F6 ], u3 B: K
剩下的三堆棋子的个数(a1,b1,c1) 满足3 b2 M/ B8 w2 @, f- ?
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
, s2 t9 a8 u8 N, ~" T& u7 J# Q) ~/ n9 q! A8 \: Q
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
2 i1 k! V- @! S总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
- I0 V8 S+ ]+ r4 b达到三堆全0的状态,那么获胜的必然是先拿的人了。
1 [6 \5 h2 t8 B- O+ d' Y2 B; ?0 D/ b/ x. p& M/ o$ H
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,5 A$ \5 Q3 U+ i. f( _
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。& [# D1 h- ~" F, d8 r! Y
6 W9 i3 j" n6 Q0 e
PS:PM偶个空间^_^ |
|