欧几里得游戏

题目描述

欧几里德的两个后代Stan和Ollie正在玩一种数字游戏,这个游戏是他们的祖先欧几里德发明的。给定两个正整数M和N,从Stan开始,从其中较大的一个数,减去较小的数的正整数倍,当然,得到的数不能小于0。然后是Ollie,对刚才得到的数,和M,N中较小的那个数,再进行同样的操作……直到一个人得到了0,他就取得了胜利。下面是他们用(25,7)两个数游戏的过程:
Start:25 7
Stan:11 7
Ollie:4 7
Stan:4 3
Ollie:1 3
Stan:1 0
Stan赢得了游戏的胜利。
现在,假设他们完美地操作,谁会取得胜利呢?

输入数据

第一行为测试数据的组数 C 。下面有 C 行,每行为一组数据,包含两个正整数 M, N 。( M, N 不超过长整型。)

输出数据

对每组输入数据输出一行,如果Stan胜利,则输出“Stan wins”;否则输出“Ollie wins”

样例输入
2
25 7
24 15
样例输出
Stan wins
Ollie wins
题目分析

先比较两个数的大小,分别用max和min表示
当max ÷ \div ÷min ≥ \geq 2时,下一步轮到谁,谁会胜 (因为在此游戏定会分出胜负,而且两者都进行完美操作。当比值大于2时,此人就有了选择的权利,他进行的下一步操作,肯定会让自己进入必胜态
所以我们需要做的就是判断在比值大于2之前或者游戏结束之前,总共进行了几次操作
如果为奇数次,Stan胜
如果为偶数次,Ollie胜

java实现
public class Main{
    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        for(int i=0;i<n;i++){
            int count = 0;
            int x = sc.nextInt();
            int y = sc.nextInt();
            while(x>0 && y>0){
                if(y>x){
                    int a = x;
                    x = y;
                    y = a;
                }
                int k = x/y;
                count++;
                if(k>1)
                    break;
                else
                    x = x-y;
            }
            if (count%2==1)
                System.out.println("Stan wins");
            else
                System.out.println("Ollie wins");
        }
    }
}```


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值