|
|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。
6 S) v$ W/ Z7 O" [对于三堆棋子的问题有一个通用的解法,如下:6 Q1 h2 B5 V, M1 [' a
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。6 b( e0 q( \9 }2 X" ^- d
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。- P& z+ @, j4 d9 F
4 D4 `2 ]! l: y
如何赢:
8 v) I- q; V7 |如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
/ f" I3 {5 M* K# |" z" L! s; C! ~剩下的三堆棋子的个数(a1,b1,c1) 满足/ ^9 Y0 @$ k: u$ A
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)
5 T6 k: s+ z1 ~ ^# P: G4 C3 `" O( V1 j) m
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
' r0 Q$ ?7 _5 L总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能$ W5 V! Y( H3 c4 {- Y9 p5 i, ]
达到三堆全0的状态,那么获胜的必然是先拿的人了。
8 A$ ?, l( m4 q* T0 j7 w5 o
% x5 R0 q2 ~. g" ?3 o5 u, l! o O如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,+ X% ?, _+ }* z: O8 M
后拿的人可以在每次拿棋子后满足这个等式,就获胜了。4 s) X& l6 p+ `0 `. }" d% g6 X
4 E+ v6 Q* U+ J; c# H
PS:PM偶个空间^_^ |
|