|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
; {) M4 S! D7 M. j* h2 D对于三堆棋子的问题有一个通用的解法,如下:
1 E* }1 g i9 e# D假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
6 b* C; @$ c! o/ P6 {# Q& O- e F如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
' n" n7 e8 f" h( U8 \$ j/ t* L
9 S7 S. N0 B7 M/ s6 h: v如何赢:* Z/ M. Q4 P% \: g0 \
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得, U; p9 A5 H. r9 L# o2 J# y. y
剩下的三堆棋子的个数(a1,b1,c1) 满足
$ i* h: u' h7 Ua1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个), Z! v/ ~# i0 @
. d {. C, @6 u$ u! L* F, ] x) D' u而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,8 X/ _5 M0 a" \; e9 R
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能
! M5 g" E- D! ^3 Z: }$ n' J- M达到三堆全0的状态,那么获胜的必然是先拿的人了。, }# L8 G9 U, M" v- G! G" W, h
" y; J0 U) o! m; T2 c如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
' }/ v, b) [9 C8 v3 j后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
- X; j) k7 \6 e% J5 y. p. F! z! h3 r9 \5 y0 s+ r- F! J+ B% q7 j' J3 K
PS:PM偶个空间^_^ |
|