|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。, Q1 u2 F5 [/ D5 q& { G
对于三堆棋子的问题有一个通用的解法,如下:
2 V, D! Q* `( {: p" A9 ?假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
+ ]: Y; n9 `7 W0 \如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
# W/ x% S% d) M8 K7 p! S( |2 ?/ _3 ]
7 {; N1 g' m% r+ U+ V. d" |7 b如何赢:5 s! O Z+ X+ V2 k: X
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
1 T8 Z) o, r! |9 E+ Y9 m: p* C5 Y! F剩下的三堆棋子的个数(a1,b1,c1) 满足
1 u8 ^: G' z& V& Q' Ja1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)9 b$ S+ L( r! w7 N
+ a3 i. `% l$ g2 Y" J# L5 ~3 d. s
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
. T$ y& X, {6 ^) Q总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能2 B7 t% l6 m) f
达到三堆全0的状态,那么获胜的必然是先拿的人了。# h- U& t* }' H- x5 F2 l e
4 K, @+ ^; _+ v7 N; V; L: Y如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,. a( E( q9 Q0 p1 h
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。# J. s0 n3 Q1 n, Z1 U$ o
/ @. D" z3 R1 w) D; NPS:PM偶个空间^_^ |
|