|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
+ C) |2 `. J. m: {) V. _7 h9 r2 L对于三堆棋子的问题有一个通用的解法,如下:
* I, e# P1 H, N6 a假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
3 t" y* ^) F" t# `4 ?1 n" J" \% k如果a^b^c=0,则后拿的赢,反之,则先拿的赢。0 F7 _ A$ u5 d) A; P
- ~6 D ?# H1 G. Y1 y
如何赢:4 R# G. q7 q. t( `( j. A& f
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得. K: a/ S" o: U4 ]& l8 I
剩下的三堆棋子的个数(a1,b1,c1) 满足: T1 U6 E8 T b& [% v! a
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)( t7 D" s0 F) i- r+ H
H3 l7 J& ?/ s5 [) V而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,; w$ M; z3 c! x. w
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
5 F3 k/ u" H& L9 S# D达到三堆全0的状态,那么获胜的必然是先拿的人了。/ \0 y$ D* j& t" V# ?
$ m, c6 ?3 F0 o- j' ^3 `如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,, | Z5 p, E# R! {1 V
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
3 T1 j9 |4 W$ a5 e) Q* T, u* L5 e8 n: I7 R4 W! }. U
PS:PM偶个空间^_^ |
|