|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
6 l2 o) V' \3 o$ U8 f" \对于三堆棋子的问题有一个通用的解法,如下:2 P0 k$ R2 @( N5 k$ [* Y/ m
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。5 j7 M9 _8 }" S' C/ N
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
" i& R* U! a5 R/ g7 [
* N( H# N5 G$ A* Y- J! L! W如何赢:1 J9 u4 N( n& J' ^) ]% X
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得4 @, z- U7 `5 x/ B7 j
剩下的三堆棋子的个数(a1,b1,c1) 满足
2 r+ `5 ?, R4 }! Z9 ta1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
3 l' q# `( m# V& M; z8 g3 [' J' }' c ~4 z- j7 p$ T7 [
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
; p- R; v2 L: H- ~' |总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能; C7 S: J7 D; Y
达到三堆全0的状态,那么获胜的必然是先拿的人了。
2 e+ l; J4 m0 W9 ^- m5 p
7 A, F% M* ^+ J9 U5 e% K& z( X/ m如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,8 D: p5 S0 U, X8 G3 X5 y! w, `! a
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
6 @, |; \$ W8 o( W5 w# M: [% X& N7 ~9 X1 K7 F
PS:PM偶个空间^_^ |
|