|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。1 E1 ?! e! D" E; [3 K! l
对于三堆棋子的问题有一个通用的解法,如下:
1 ^3 O' _" ?8 v5 c7 c假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。3 j5 ^& M; V$ i% q7 n+ `4 H
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。 ~1 `/ Q; C" g+ s
1 u1 p# o2 {) P
如何赢:
: ~: h/ ?6 O- S如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得' C, B4 z! t8 T l8 k: q: s
剩下的三堆棋子的个数(a1,b1,c1) 满足2 ], f, u* Q3 s3 k9 |* c& n
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)7 G7 a. V1 d% E) M& r; ]6 }: M: z
+ {" d+ N0 P8 a' X而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,1 @+ j1 x# ]& T) b& Q" C
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能6 H8 Q/ \; _& i( L+ p+ r8 [
达到三堆全0的状态,那么获胜的必然是先拿的人了。% l) _8 @8 |$ ~0 l& `) b
# O1 J5 f& ~+ k+ _
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,% s' Y! U' G# ?) `2 |
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。3 h6 N7 E" a |: H" O
: c9 n" o9 Q( ?1 d+ TPS:PM偶个空间^_^ |
|