|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
3 U( l, k' k( x* n, i6 m; x对于三堆棋子的问题有一个通用的解法,如下:/ f' H' W! ?- w4 k1 `6 ?
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
2 |$ }0 d+ q- z0 x3 m5 i! ~5 H如果a^b^c=0,则后拿的赢,反之,则先拿的赢。3 g4 S' Y& T r8 O
2 O# @: j1 s# t( P' `) S如何赢:
( o7 D( }3 U/ c$ ?如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
( k4 n: A+ G9 m2 T) W; t9 D. Z剩下的三堆棋子的个数(a1,b1,c1) 满足! h' P: Z; m; d& w
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
# _' g$ y, D3 B& w6 s: i
5 J5 |& ]. A7 D/ v6 T6 [4 z而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,4 f z! _8 H5 R6 K& ]
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
7 G, @# A1 j1 K( q* r; L% T达到三堆全0的状态,那么获胜的必然是先拿的人了。
, W3 A9 c- T+ b5 P2 I- Y* c3 ]! z5 G7 ~, v
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
3 f* m$ g. c) J+ |. V) e后拿的人可以在每次拿棋子后满足这个等式,就获胜了。3 Q1 N y' w; _1 y# B
$ m# F0 }5 e4 r4 u0 B
PS:PM偶个空间^_^ |
|