|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。& e) s' }4 s7 L5 o! f2 W
对于三堆棋子的问题有一个通用的解法,如下:2 w v* q2 @, q, C# `* Q8 H; x0 M
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。. Y( V" D7 R* a) F
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
) q5 _+ _) e E$ T5 C" v+ R( ~- s3 o; W) Z' I% l* B1 {
如何赢:0 F! Q# v1 y: X3 F6 I% v4 b
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得) v2 @. M. q$ e3 |6 L* k& [; x
剩下的三堆棋子的个数(a1,b1,c1) 满足
4 Z! a) ?0 r e1 O$ Q; J% P: b2 ra1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)) E0 `) Q' A% B" R) Y+ I' o2 _
2 n$ Y3 s: m7 u0 k7 E5 |+ F而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,& \ C* a- o1 ?6 L5 G
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能; j4 ]% b0 B$ H: _
达到三堆全0的状态,那么获胜的必然是先拿的人了。
m3 E( g, g1 E# L0 K4 }3 D, `4 i. t! x) q$ F0 ?3 [* m1 i
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,+ ]: K4 ^+ X0 g6 \* Q% k
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。; g0 W$ w% \. b/ Q, f
4 z4 `1 o3 r6 V: k7 u' S6 [( O
PS:PM偶个空间^_^ |
|