|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。0 w! i" q/ r6 ^2 o W& g0 L
对于三堆棋子的问题有一个通用的解法,如下:
- `1 y3 u; y+ ? d- t+ j假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
( ^" ~! d+ d' j+ k$ M! L如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
! ^ p. z3 y+ Q A$ Q: o
" U9 f3 \" p k T! q如何赢:5 }+ p5 S/ S! x7 Y# i3 W4 b0 R
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
% }+ b& |- S; F! X, c7 n2 m$ |剩下的三堆棋子的个数(a1,b1,c1) 满足5 H. u N0 f7 q5 I1 p" X! b
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)- c& @9 c+ C4 m, `: t
1 {$ d9 }, L" J4 E
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
8 y* Q P* n$ b( Z" X+ L总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能2 g; Y' K: ~8 \- R d( F
达到三堆全0的状态,那么获胜的必然是先拿的人了。& T, y+ G4 I0 a* u
@) Z0 o: r y& E. F如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
% J. ~" ^( q" Y, i3 l/ J- T后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
9 H1 j* |5 B! H( t' g c: X9 M/ _/ G' J
PS:PM偶个空间^_^ |
|