1218:取石子游戏

题目:

        

有两堆石子,两个人轮流去取。每次取的时候,只能从较多的那堆石子里取,并且取的数目必须是较少的那堆石子数目的整数倍,最后谁能够把一堆石子取空谁就算赢。

比如初始的时候两堆石子的数目是25和7。

25 7 --> 11 7 --> 4 7 --> 4 3 --> 1 3 --> 1 0
  选手1取   选手2取   选手1取   选手2取   选手1取

最后选手1(先取的)获胜,在取的过程中选手2都只有唯一的一种取法。

给定初始时石子的数目,如果两个人都采取最优策略,请问先手能否获胜。

输入:

        

输入包含多数数据。每组数据一行,包含两个正整数a和b,表示初始时石子的数目。

输入以两个0表示结束。

输出:

        如果先手胜,输出"win",否则输出"lose" 

样例:  

输入样例

34 12
15 24
0 0

输出样例:

win
lose

代码:

#include<iostream>
#define N 50
using namespace std;
int main()
{
    int n,m;
    while(cin>>n>>m&&n&&m)
    {
        int i=0,c;
        if(n>m)
        {
            c=n;n=m;m=c;
        }
        while(m/n==1)
        {
            c=m;
            m=n;
            n=c%n;
            i++;
        }
        if(i%2==1) cout<<"lose"<<endl;
        else cout<<"win"<<endl;
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/wentong_xu/article/details/80837054