|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。" Z( n- k D6 C- P& A
对于三堆棋子的问题有一个通用的解法,如下:# t5 s6 q3 `6 }
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。3 l* G% x* b) e% Q% n; Y
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
" c3 v5 `9 l1 M& Q) _9 J* |( a: i$ c. {' C1 j
如何赢:( k: l( S* ^( L9 G( q
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
: i9 q: B! _ v( A1 C$ m5 E剩下的三堆棋子的个数(a1,b1,c1) 满足
9 T( M& S, K7 Ha1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
, x, F: b0 c3 {" m! y* b7 k& c" r1 [; [
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
2 E* X( `7 S' t1 y% \1 v* |* g9 N总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能) j" X! v9 U( ^# v, a
达到三堆全0的状态,那么获胜的必然是先拿的人了。6 Q! Z, z1 C* T! D; K0 u
4 W5 J7 w2 q! H! o7 Z& p" L6 ~+ s
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,% }: Q2 ]; {! p R2 }* t# i
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
% e$ M9 h0 {2 L: }- R+ z a' P6 j! d
5 l& e+ ?) F3 d; w- K" s" h- m! I* mPS:PM偶个空间^_^ |
|