题目描述
LTL 和清华哥玩取石子游戏。他们的游戏是这样的:有两堆数量为 a 和 b 的石头。游戏开始两个人轮流取石子。游戏规定,每次有两种不同的取法,一是可以在任意的一堆中取走任意多的石子;二是可以在两 堆中同时取走相同数量的石子。最后把石子全部取完者为胜者。现在给出初始的两堆石子的数目,如果轮到 LTL 先取,假设双方都采取最好的策略,问最后 LTL 是胜者还是败者。
输入格式
输入包含若干行(不超过 100,000 行),表示若干种石子的初始情况,其中每一行包含两个非负整数 a 和 b,表示两堆石子的数目,a 和 b 都不大于 1,000。
输出格式
输出对应也有若干行,每行包含一个数字 1 或 0,如果最后你是胜者,则为 1,反之,则为 0。
样例输入
2 1
4 7
8 4
样例输出
0
0
1
一,题目简化
威佐夫博弈
三,题目代码
#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
int main()
{
int a,b,x,k,num;
num=(1+sqrt(5))/2;
while(cin>>a>>b)
{
if(a<b) {x=a;a=b;b=x;}
if(b==(int)((a-b)*((1+sqrt(5)))/2)) cout<<0<<endl;
else cout<<1<<endl;
}
}