|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
+ L T, Q) i6 K' @; h9 Z对于三堆棋子的问题有一个通用的解法,如下:
. o+ {1 @* K8 h假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
6 F3 I; i6 X$ f5 G如果a^b^c=0,则后拿的赢,反之,则先拿的赢。* ]2 i& m$ U- G% w$ A3 a3 E
- L2 W0 c; K8 z ?* i5 q如何赢:
/ }1 m1 p, M( Y5 y- r" H如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得% f" ^0 j9 Z; z9 L' e. \* C" G
剩下的三堆棋子的个数(a1,b1,c1) 满足
6 Y: P7 |: q# K( \; Ma1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
' r0 @. s C7 E8 A7 h/ I7 Q C/ S$ ^1 `+ u( U
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,& x/ t( \8 p) K
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能3 B* z7 z: Z7 |" P, [* z! O
达到三堆全0的状态,那么获胜的必然是先拿的人了。
& a' M8 ]( O, v5 m7 _ F& k) I, N# j0 I) x8 J
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,2 v1 O: M$ y4 f7 m2 \5 h
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。& U# g) a. J# m2 g% \3 T$ V
5 k1 t: \/ W& [) J; s* ~7 y
PS:PM偶个空间^_^ |
|