|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
; ^: S- H' f) @" P- z对于三堆棋子的问题有一个通用的解法,如下:( {, p- v; e: t d$ f- r
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。% m( }+ U. T7 _8 g
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
9 s( W3 r& g0 O; W m% W7 L- K1 T5 X" A3 U9 K# I
如何赢:
4 G7 Z$ [5 j+ ^* r i& i3 O: Y" X+ Y如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
n2 d* \/ | w! R! {7 @# n剩下的三堆棋子的个数(a1,b1,c1) 满足
1 e7 Y) x8 j1 g* c# F# ?6 Aa1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个): ?/ L& t! b' e3 K( L) v' A
1 N- G9 k' Z- w5 p) d
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
* W- T9 Z" `7 S6 | e; y$ W$ x总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能( g8 Z8 U3 d4 c8 a4 |
达到三堆全0的状态,那么获胜的必然是先拿的人了。
. D0 c% ]# K' T4 U: W- ~
( [+ n; ^, a! M8 `如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,7 |3 ~( O5 e/ p3 ~/ R$ R6 Z) T( {
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。/ ` x% ]: S2 c, b
1 U% B; v; t P1 rPS:PM偶个空间^_^ |
|