|
发表于 2006 年 1 月 1 日 14:25:11
|
显示全部楼层
答案是:先拿的人赢。/ u8 a1 r4 e+ m/ B" l/ d
对于三堆棋子的问题有一个通用的解法,如下:9 Y1 v$ b/ d& C+ }( g
假设三堆棋子的个数的二进制表示分别是a, b, c,用^来表示二进制的异或。4 n" P8 K/ K& s ]. o8 ~, t0 E
如果a^b^c=0,则后拿的赢,反之,则先拿的赢。
2 t7 [" n+ R# w5 m4 r4 T; z9 ]3 i) e$ e, z1 e! |
如何赢:6 o; X' T# D" U4 b5 y
如果a^b^c不等于0,那么先拿的人总可以做到每次拿完棋子后,使得
( z$ {2 W4 O: X. X剩下的三堆棋子的个数(a1,b1,c1) 满足# y- O7 H: X3 G: c- g2 m
a1^b1^c1=0 (本题中,先拿的人应该从9里面拿4个)$ ], W1 O# d+ D( a& b1 A
: F8 U+ g9 Y$ p5 _* e
而后拿的那个人无论拿哪一堆都会破坏这个等式的成立。如果先拿的人每次拿完后,
; \4 D; i: R! H/ r7 Y1 `总是使的剩下的棋子数满足这个等式,后拿的人每次都破坏这个等式,也就不可能8 T5 \6 h( y) L$ c3 H
达到三堆全0的状态,那么获胜的必然是先拿的人了。, @, E3 \- }) a. r' [. U
, o% I! S1 ^0 X2 m* g
如果一开始三堆棋子的数就满足a^b^c=0,那么先拿的必先破坏这个等式,
9 N* X/ p& S7 L9 f5 u& d+ W& `后拿的人可以在每次拿棋子后满足这个等式,就获胜了。
' n" Y, o& ]# W4 h9 X- n) p" m. j; ^0 q% i
PS:PM偶个空间^_^ |
|