|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
) |) x) a6 \/ W" M/ j9 _对于三堆棋子的问题有一个通用的解法,如下: Z1 z3 r Y& V" u* ?# a: k$ n
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。, a) @2 V5 j( b6 Z) A; E$ R8 }( i% ^
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。$ t# g* P. d9 n9 r- s, E" i: V" ~% C
$ z* G7 g! N; Z( I: s如何赢:
E, R) n0 n! |7 ?如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得$ n: O, w5 M! G' |
剩下的三堆棋子的个数(a1,b1,c1) 满足& Z5 x9 t" e; n6 A$ b5 E3 X
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)" J: J' u8 f Y. f
3 a' m8 ?# S v而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
% D. k) m4 c' a6 D总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能- Q8 X- ?" Z' E6 h E
达到三堆全0的状态,那么获胜的必然是先拿的人了。: b4 D6 N( E5 D3 \
' }: O, J6 n @2 g. T5 z1 X3 p如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,* x; ?+ r) G7 J" h" G6 ^
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
- W! e4 Y2 @3 l, i8 h, y$ Y& y l+ _! o( G4 j& D* |# ]. v1 }
PS:PM偶个空间^_^ |
|