|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
5 U1 F' \8 ^0 L" v% w# Y对于三堆棋子的问题有一个通用的解法,如下:
2 q# j- J# f2 i3 c O L假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
) k4 i! E. n2 \5 H) H如果a^b^c=0,则后拿的赢,反之,则先拿的赢。 r6 Z2 `# i, N7 ~, W6 v
. b. D% ?8 O: V# R6 j( H0 C1 ^
如何赢:
" V+ c8 g( N6 h7 t' q如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得8 U* n o; O# D4 J4 s3 T
剩下的三堆棋子的个数(a1,b1,c1) 满足8 Q8 ~2 y, o( z, o% L' p6 S: I# E4 Z: F, k
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
, B: `/ n/ D2 [1 G. Q
% g* q" y; F: _ t而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,; \, a& [5 v$ h% @2 g
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
, E X) d3 |( ^ v* t. ^达到三堆全0的状态,那么获胜的必然是先拿的人了。
+ a d2 q! F7 I- |# P" A! e( U+ v. U8 O: C
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
9 g- _( X9 C2 k. Q5 `( Q0 W3 D后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
5 f/ {+ F# S2 ^& p7 \7 P
1 B. J3 _; l& v( iPS:PM偶个空间^_^ |
|