2 1 8 4 4 7
0 1 0解题思路: 看到这种博弈题目,第一反应就是其中存在一定的内部规律: 这个游戏就是所谓的威佐夫博弈(Wythoff Game),果然够简单,够经典————“黄金分割!!!” 观察这组数据: ************************************************ 第一堆 第二堆(不区分两堆先后顺序) 差值 0 0 0 2 1 1 5 3 2 7 4 3 10 6 4 13 8 5 ................................................ 前几个必败点如下:(0,0),(1,2),(3,5),(4,7),(6,10),(8,13)…… 可以发现,对于第k个必败点(m(k),n(k))来说, m(k)是前面没有出现过的最小自然数, n(k)=m(k)+k 而: m(k) = k * (1 + sqrt(5))/2 n(k) = m(k) + k 这两个公式不知道为什么是这样?好像是威佐夫博弈(Wythoff Game)的一部分 求大神解读...#include<iostream> #include<cmath> #include<algorithm> using namespace std; const double q=(1+sqrt(5.0))/2.0; int main() { int a,b,x,y; while(~scanf("%d %d",&a,&b)) { x=min(a,b); y=a+b-x; if(x==(int)((y-x)*q) { cout<<0<<endl; } else cout<<1<<endl; } return 0; }
原文地址:http://blog.csdn.net/holyang_1013197377/article/details/40346925