|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
! Y/ F% _/ z3 e$ m0 f对于三堆棋子的问题有一个通用的解法,如下:/ _2 H. i8 h6 k9 m, d8 y* q
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。+ Q8 I @% Q0 V# d. X3 B. D8 C- D2 `
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
( F3 J6 E, f+ n1 V$ o/ e' y( ~. _" g; F8 U
如何赢:
9 T/ Q9 v! y2 ~6 F# i* \; b如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得0 l( I( u6 c8 K
剩下的三堆棋子的个数(a1,b1,c1) 满足2 p+ O+ R. C; l4 w$ k" p
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)) d6 W% e6 r0 ]) P( O( C h) { b
! x/ M+ p$ W3 K7 B而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
" [1 N: N6 C; G+ ~* T* @- W总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能) C1 z0 d6 }1 c; G
达到三堆全0的状态,那么获胜的必然是先拿的人了。
k6 P9 `4 K" E& K" }+ F& Q1 h5 i8 y6 ^; j, K% Q0 ]
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
9 C; P7 Y- ]* n; j0 O8 w后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
! ?& k e9 _# r' {5 w+ P! p: M. _* ~* q p/ c+ L# Q
PS:PM偶个空间^_^ |
|