|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
8 Y3 h ]+ n7 J- U6 ]对于三堆棋子的问题有一个通用的解法,如下:
, I( `8 F+ R2 I1 R假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
: D y% Q! O) `" ?如果a^b^c=0,则后拿的赢,反之,则先拿的赢。1 i8 a' t3 R n* ?; s# ^, x
% C! e2 ?. g. l; E- m3 W" n" o
如何赢:1 t, V& {6 a2 W0 ~; j: A
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得" z1 x& W' U& w6 c D
剩下的三堆棋子的个数(a1,b1,c1) 满足( U' M9 X: O4 n+ c# [( U
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
# j; ~: y; C- `9 g
0 [5 M% p2 x) p+ D) k而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
+ L# h0 A& v4 c8 A3 H1 r" Z; f" e总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
+ o0 G/ p0 }/ @8 ?+ c1 P达到三堆全0的状态,那么获胜的必然是先拿的人了。3 R2 U$ ^) l. z2 j: O1 K3 n7 O1 b9 k
3 K# n) I% |& j
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
! Y6 w) K5 [, w4 k* e }后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
! |/ Q" e. [' K' f, A$ T* i& ^) J y7 M& z, I
PS:PM偶个空间^_^ |
|