|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。" E% n6 F, S- k
对于三堆棋子的问题有一个通用的解法,如下:; k' J& p9 s2 M( J( n! b
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
@9 f6 p+ G6 ^/ O; r& ]" ^* U如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
# r- t& V. N2 R3 j% B7 p3 E
) t! `7 _9 {0 h5 F% [3 h如何赢:
) k, _: ?4 e; G$ P& _如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
" f9 Y% j, ]% n' `剩下的三堆棋子的个数(a1,b1,c1) 满足' A) {; G3 ~/ r- N7 u
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
; T; G. x$ |/ \0 h7 V' N1 b" j6 [- V/ N+ E8 D7 Q" B4 i
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,, S* i* s, t$ p N* N
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能1 ~0 a4 I8 P$ S: a
达到三堆全0的状态,那么获胜的必然是先拿的人了。4 y) Z9 m2 R! y# v S0 r0 b
0 O' {, d/ `9 n7 [
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,5 v, P+ `& j4 g' |. O- ~3 v
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。( H* G3 T$ T6 W% C5 Q1 c% \; k. B
- D+ ~( f8 S2 B+ D( G' @PS:PM偶个空间^_^ |
|