|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。/ t) E5 F2 z' D5 R7 Z/ a
对于三堆棋子的问题有一个通用的解法,如下:
$ a5 n' D: r8 p# Q! e! ] J! d P假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
! ~( Z3 }, G' M' t2 T如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
5 e( O8 y2 U4 B, J+ F1 }1 Z3 s# X8 x0 o) a R! s S
如何赢:
- s4 u% w2 F3 K/ p a0 c3 a$ a如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
4 C$ p8 m; [+ e+ m W+ S剩下的三堆棋子的个数(a1,b1,c1) 满足( Q; |: |4 b* S" Y" ]6 U b1 E
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
h t1 z1 ?# v. c9 m8 i! \( P; W9 D3 ?' s
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
6 d' N6 k3 E+ z5 N7 C总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能9 m+ K, u. Y4 T! z& [ S
达到三堆全0的状态,那么获胜的必然是先拿的人了。
8 z% i# o4 D$ `% F, t5 P/ M! y: ^3 h/ }7 m
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
$ c( L& t, X$ n$ y9 w6 k: o后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
/ P( d. G V' y, c/ o: O0 R( l1 \* I8 w8 R9 d4 ~
PS:PM偶个空间^_^ |
|