|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。/ s2 m3 T% w$ z! G5 [
对于三堆棋子的问题有一个通用的解法,如下:+ b; {4 k0 t2 ?
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
; y9 l0 L, d/ g" ^+ |如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
5 I, D7 [6 S+ a2 A% r% o4 r4 k2 }# s- S" _1 S& a
如何赢:
% @) u, ~, c5 _如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
$ W F: \! g6 E6 U1 S# G剩下的三堆棋子的个数(a1,b1,c1) 满足+ ?, {7 N! o0 A8 n# \( R
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个) ?# [" J/ j n% N* s) v
2 @. l( x) |) p7 b4 ~" I
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,2 L* G2 ^2 U9 S. N7 t
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
4 g9 T3 J9 a: M- V6 @& {; e" P达到三堆全0的状态,那么获胜的必然是先拿的人了。
$ h! ]2 K6 ~9 t( [, {2 T8 x# y4 I- i1 [1 i: V
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,0 J2 k/ A3 ]7 T- V( _
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。# u0 d4 o2 K1 P, o
- v, O9 W6 Q0 A* S. R G3 KPS:PM偶个空间^_^ |
|