|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。 u; }8 d" p* G8 d# U/ p; Q
对于三堆棋子的问题有一个通用的解法,如下:
* i$ Z5 k; l" Y/ ^) s4 D. p4 {6 E假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
9 N5 t& ]3 p7 F5 _4 ]' i- \如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
1 d8 }2 ~$ w7 Q% T- x' J# |2 k4 ?' O2 l0 z# {
如何赢:$ Q a8 w9 y0 M. ?7 a
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
y9 H; D: l: O剩下的三堆棋子的个数(a1,b1,c1) 满足
+ T; h% E" _! b5 @a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
% h$ x h8 a) X" c6 f. {
, H: F D3 P/ U而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,' R+ A1 H4 ?- u7 P3 Y* Y w4 U4 s
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
9 b) b" F9 k7 t+ s# ?4 ?达到三堆全0的状态,那么获胜的必然是先拿的人了。
" I3 o+ B; d/ }5 `& ?: R9 J- r6 _
& X5 x+ W6 m' l+ S' l如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,$ q9 h* p' I6 L9 z: ^! ?3 o
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
: N3 v0 E1 i4 u' o5 v; Y' j4 S! L5 n/ K6 G3 i6 g
PS:PM偶个空间^_^ |
|