|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。; n, @8 m& Q: m* L
对于三堆棋子的问题有一个通用的解法,如下:
1 G8 G2 z \8 F% S! |假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
5 E$ d$ s3 X: y3 @4 l' R& R+ n如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
. L. [' I' U- d/ v- L/ X1 |) M% j9 T& _
如何赢:
' w( a! I: J! Z7 V1 R; {1 H0 t( a如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
3 t" i/ t9 h+ V8 g) o) \剩下的三堆棋子的个数(a1,b1,c1) 满足 \8 O+ @) S+ B6 `
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)/ D% g4 o! j6 D' [
' e, \/ u& U2 A6 \3 a; M而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
, h I( \0 ?/ ^* y8 U+ s* P总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能 U s+ ^1 O& c. g3 i
达到三堆全0的状态,那么获胜的必然是先拿的人了。
" f" l$ w5 B1 D2 ^. H) h, G/ r% ^4 m8 Z' v) V% g
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,, ` a$ l$ E" R1 C) ~
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。/ ?0 u. a( @3 h. ~+ k4 ^0 f+ W, d
# w3 Y' e' t3 x/ x/ M( c* ?PS:PM偶个空间^_^ |
|