poj 1067取石子(威佐夫博奕)

/*

*威佐夫博奕(Wythoff Game): 有两堆各若干个物品,两个人轮流从某一堆或同时从两

*堆中取同样多的物品,规定每次至少取一个,多者不限,最后取光者得胜.

*(ak,bk)(ak bk ,k=0,1,2,...,n)表示两堆物品的数量,则

*奇异局面(先手必败, P-Position) ak =[k(1+5)/2], bk= ak + k (k=0,1,2,...,n 方括

*号表示取整函数)

*/

 

 1 #include<iostream>
 2 #include<cmath>
 3 using namespace std;
 4 
 5 int main()
 6 {
 7     double arph=(sqrt(5.0)+1.0)/2.0;//黄金分割数
 8     int a,b;
 9     while (cin>>a>>b)
10     {
11         if (b<a) swap(a,b);
12         int n=b-a;
13         int c=floor(n*arph);
14         if (c==a) cout<<0<<endl;
15         else cout<<1<<endl;
16     }
17     return 0;
18 }

 

posted @ 2012-04-13 10:10  AndyDHG  阅读(163)  评论(0编辑  收藏  举报