|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
) {* n) V% {$ T" m6 [ S' q对于三堆棋子的问题有一个通用的解法,如下:3 H$ x. {! V- L7 C8 g
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
6 m7 ?: B( N2 R: y: b. s! D如果a^b^c=0,则后拿的赢,反之,则先拿的赢。' R7 z5 Y, L! ]
3 T# ~& C! f( B( R/ M如何赢:
P! W; F. `! ~( }0 `! U3 F如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得/ u: J! d5 L- b. o$ {
剩下的三堆棋子的个数(a1,b1,c1) 满足
" c- ^7 X* p% r5 ^a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)0 r7 D* C1 o+ z6 ~( J( j( U2 g" @
/ \ p2 ^4 O; r5 S5 K) Q
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
5 B u0 {1 H# x' f; B$ X/ ~+ {总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
0 ]# |$ O; x; Y) h8 o达到三堆全0的状态,那么获胜的必然是先拿的人了。' o/ C4 V& q O# W+ w& D! v3 F
6 z: e/ \2 U2 A0 N% l+ C
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,, S; ]7 a% g/ _; M
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
7 n; t2 h6 r, T: y0 n% H4 h( j* R8 N$ ]/ F" K( S$ z4 ~" m
PS:PM偶个空间^_^ |
|