|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。4 \' U$ v m8 k* X! l* |- N
对于三堆棋子的问题有一个通用的解法,如下:
5 e: r4 j' q" M4 B假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。$ ~ \, `: W8 `1 V. b& r5 C
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
7 d- \1 g* g7 Z1 |# `) ]7 @4 H3 t6 @
: F% X! P5 @, I) f& t- o: J' v. f9 w如何赢: t3 S- O9 x+ v. l
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
+ V5 M$ K" T1 U1 z( V& @剩下的三堆棋子的个数(a1,b1,c1) 满足
" \- S# Q5 i/ g% A- a' Ba1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
) [' K* N& n6 a; k6 z
9 d9 G* b6 @/ P而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
& K8 t4 F, a9 S& E. R总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
) E% P6 @& m# T7 I" C0 z达到三堆全0的状态,那么获胜的必然是先拿的人了。
9 t1 p% V: s- _/ I9 }( T8 ?% P+ U" h& D' z) ` j
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
; L% G+ {, Z+ j, ~- ?" p后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
' f w1 v+ H5 z3 ]0 h! v8 B$ H/ T9 F( O
PS:PM偶个空间^_^ |
|