|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。! i# c8 I9 F' M. m3 M; M
对于三堆棋子的问题有一个通用的解法,如下:6 C2 f5 X& H( v5 T
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。 L" [0 v; ]$ x. p6 k, I
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
! w1 G& a& r9 Y7 _& H5 B& H4 s, ^4 y
如何赢:
/ i; q2 u' Z) f. r如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得& y& X" w' F# i
剩下的三堆棋子的个数(a1,b1,c1) 满足
; |1 w& Q+ |2 C! t& Ia1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
( ^, z+ y4 m) }! Y, I
3 _ Q5 }) K; m( Y# G' Y而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,+ {% O% q6 _8 M& K7 v- z" p
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能: }- }" U% B- x2 p7 v
达到三堆全0的状态,那么获胜的必然是先拿的人了。
, K6 N4 b7 H# J2 e) k
$ z. i+ i: E1 D( C" p" P如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,4 |* ~! _. A( Z" }
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
2 i# Z b6 i! U I( C
+ l7 S" E) t* j4 B( @0 T5 Q, aPS:PM偶个空间^_^ |
|