|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。. A% H1 a8 |4 o( w+ O
对于三堆棋子的问题有一个通用的解法,如下:! I0 e1 M2 g, N* q- g
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
. i4 X( k$ }+ b; l0 p2 g' ^% F- A如果a^b^c=0,则后拿的赢,反之,则先拿的赢。. @: F" I, A' b) S/ k+ |3 x
1 }! H& I" M* y4 N. p: _
如何赢:* x$ u) j, c$ p% M: }
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得0 C& b- b: K3 |
剩下的三堆棋子的个数(a1,b1,c1) 满足3 c% M0 |7 F8 F& J- ]4 u* p
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
8 C ~$ N: f* @4 _) N( W7 j# v
+ A& F* M) O9 }% r而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
( I4 l4 e. [6 i; r总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
# e" v/ O1 k( I0 P达到三堆全0的状态,那么获胜的必然是先拿的人了。
; {& B- \0 R" o3 k- c* v- b4 k0 y7 L; y K1 }' P6 Q" z' |; g
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
9 X3 B% X) T( a$ \/ I后拿的人可以在每次拿棋子后满足这个等式,就获胜了。% j9 S: G, S6 q# ]2 {- \) e
, _( f# J |$ M& B& r2 hPS:PM偶个空间^_^ |
|