|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。2 u5 g, B1 y+ W2 O
对于三堆棋子的问题有一个通用的解法,如下:
! S. [ G" n/ N& H1 P' E" z假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
4 J5 J2 Z: Y% w7 R2 \如果a^b^c=0,则后拿的赢,反之,则先拿的赢。. [1 m4 ^ ^4 J, U* L
8 l% \) |. z8 l+ s如何赢:
9 {# z, h$ J. j. m9 m$ e如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
/ j* q: [* A3 O/ F% B- i _剩下的三堆棋子的个数(a1,b1,c1) 满足; B9 d- h# Z8 G$ J6 c, }/ s2 p1 \
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)) D0 k! j1 ^7 T6 ~$ d
4 p, t& J/ T. d5 j" M7 ]; C0 z
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
- W6 h6 v, g9 y0 Q1 r总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能+ m! e1 ?6 g& s4 {- X3 C* f# z
达到三堆全0的状态,那么获胜的必然是先拿的人了。. {/ U5 l$ C1 }8 ?
1 o; g5 F! w* y; N |如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,2 T/ G5 @7 ^0 d; `1 n- w% c" w8 T9 y
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。4 `4 S6 ?; M" p
7 O: b- W3 }0 @8 w- C( h. w$ e% E2 wPS:PM偶个空间^_^ |
|