|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。. B# s/ f* D2 ^4 {" {* V4 E
对于三堆棋子的问题有一个通用的解法,如下:: A- c+ C2 ~$ y2 C6 N0 P6 N
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。/ o- {( \9 |0 C1 g+ [, ^
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
8 C0 z/ n( W& `7 J! ~& x4 v6 ^* K3 F& G6 ^- J4 x8 s+ \% P! V
如何赢:
i. f3 K6 W. T0 ]8 N7 z如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得8 v- \8 X0 w% q4 Y
剩下的三堆棋子的个数(a1,b1,c1) 满足
+ T% [! Z [/ w% F/ O Ca1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)9 h* i2 |, p* N' ^# t, [$ a' G
8 Q! x, {5 h% o3 q' ?+ x3 w而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,! _( G8 g7 D) k4 t5 ~' U6 Q+ V5 R+ N
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能 e# }5 i, J% K3 ^0 J2 \
达到三堆全0的状态,那么获胜的必然是先拿的人了。0 Q: p& k% \6 t/ T& ~
+ e8 D8 x4 B( q- o如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,' u: Q4 h$ I: f0 E( s+ ?
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。! R3 X0 D0 x' n, Y! [+ Y
; i4 k' U, w6 E' FPS:PM偶个空间^_^ |
|