|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
4 ^& T* @. c) K6 v' X8 P对于三堆棋子的问题有一个通用的解法,如下:" W6 @, A! w2 n5 V# e$ X
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。
) c0 Y: B6 d) \9 _. K: ?( N6 `5 _6 q" b如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
" l* a: ?# L, E/ x$ h: n* r1 H# e6 Z1 P$ R& A
如何赢:
4 `: B6 p1 p+ F ]2 g& Y4 {如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
+ u+ P( o+ {) r9 I剩下的三堆棋子的个数(a1,b1,c1) 满足% w$ T" [% V; K2 n8 C& g4 ]
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)2 V: Z+ d/ i3 i& g2 t6 ^, b; j
; M5 y: U- T j8 ~而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,% w" I( P1 F! Q) l# [+ S: R
总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能# B* `3 t: c+ l8 S8 Z0 I: @4 v3 [
达到三堆全0的状态,那么获胜的必然是先拿的人了。% B( U' D. N3 |, r8 T
; U! f- K$ B9 B( Z1 @
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
$ E- z, [# R6 z* d8 F: ^3 t后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
' z3 p& |! V8 p3 Y) R Q! _0 l4 h5 M
PS:PM偶个空间^_^ |
|