|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。( j) @ `& f$ [ m/ z
对于三堆棋子的问题有一个通用的解法,如下:4 F6 K! F9 E# ]) }! D5 t
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。: _, \7 a& _2 r6 {% ~ M
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。0 |" R) a: f9 G
9 c' F# u4 n. s; o9 O
如何赢:
$ H+ S; |; |7 l如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
3 v" R; P& O3 B7 c8 A+ H* r8 h6 R+ o. \剩下的三堆棋子的个数(a1,b1,c1) 满足
6 q5 z2 G+ X4 Z; y; y9 |! d' va1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
5 k$ m* \+ v- z. O8 }# f, K# s% N& D" _$ E7 y
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,2 `/ k7 }; u1 v/ b
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
/ a1 A5 i' L7 k7 t( K达到三堆全0的状态,那么获胜的必然是先拿的人了。
6 `$ | A/ f+ a; C+ B7 v# v4 w' Y# Y: y
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,8 ^/ ^5 j' I( I7 K( h! N0 O
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。& E ~* t* O5 R: d$ c8 S' c* S
: w' j2 Q3 A" J& P! l: i+ Z; x
PS:PM偶个空间^_^ |
|