LCM应用:无输出

时间:2017-09-26 13:22:23

标签: java lcm

我正在解决这个问题

在数字线上有两个袋鼠准备向正方向跳跃(即朝向正无穷大)。第一只袋鼠从位置x1开始,以每次跳跃v1米的速度移动。第二只袋鼠从位置x2开始,以每次跳跃v2米的速度移动。鉴于每只袋鼠的起始位置和移动速度,您能否确定他们是否会同时降落在同一地点?

这是我的代码

import java.io.*;
import java.util.*;
import java.text.*;
import java.math.*;
import java.util.regex.*;

public class Solution 
{
    static String kangaroo(int x1, int v1, int x2, int v2) 
    {
        // Complete this function
        String result = new String();
        int count = 0;
        if(x1 < x2 & v1 < v2)
        {
            result = "NO";
    }
    if(x2 < x1 & v2 < v1)
    {
        result = "NO";
    }
    int distance1 = 0, distance2 = 0;
    if (x1 > x2 & v2 > v1)
    {
        for (int i = 0; x2 > x1; i++)
        {
            x1+=v1;
            x2+=v2;
            if (x1 == x2)
            {
                result = "YES";
                count++;
                break;
            }
        }
    }
    //else
        //{
            if (x2 > x1 & v1 > v2)        
        {
            for (int i = 0; x1 > x2; i++)
        {
            x1+=v1;
            x2+=v2;
            if ( x1 == x2 )
            {
                result = "YES";
                count++;
                break;
            }
        }
        }
        //else
            //result = "NO";
    //}
    if (count == 0)
    {
        result = "NO";
    }
    return result;
}

public static void main(String[] args) {
    Scanner in = new Scanner(System.in);
    int x1 = in.nextInt();
    int v1 = in.nextInt();
    int x2 = in.nextInt();
    int v2 = in.nextInt();
    String result = kangaroo(x1, v1, x2, v2);
    System.out.println(result);
}

}

输入:0 3 4 2 我得到输出:没有 正确输出:是

提前致谢

P.S。 - 我正在寻找代码问题

1 个答案:

答案 0 :(得分:0)

您的方法可以简化为:

static String kangaroo(int x1, int v1, int x2, int v2) {
     return (x2 - x1)%(v1-v2) == 0 ? "YES" : "NO";
}