蓝桥杯之VIP试题 龟兔赛跑预测

题目:VIP试题 龟兔赛跑预测

问题描述
  话说这个世界上有各种各样的兔子和乌龟,但是研究发现,所有的兔子和乌龟都有一个共同的特点——喜欢赛跑。于是世界上各个角落都不断在发生着乌龟和兔子的比赛,小华对此很感兴趣,于是决定研究不同兔子和乌龟的赛跑。他发现,兔子虽然跑比乌龟快,但它们有众所周知的毛病——骄傲且懒惰,于是在与乌龟的比赛中,一旦任一秒结束后兔子发现自己领先t米或以上,它们就会停下来休息s秒。对于不同的兔子,t,s的数值是不同的,但是所有的乌龟却是一致——它们不到终点决不停止。
  然而有些比赛相当漫长,全程观看会耗费大量时间,而小华发现只要在每场比赛开始后记录下兔子和乌龟的数据——兔子的速度v1(表示每秒兔子能跑v1米),乌龟的速度v2,以及兔子对应的t,s值,以及赛道的长度l——就能预测出比赛的结果。但是小华很懒,不想通过手工计算推测出比赛的结果,于是他找到了你——清华大学计算机系的高才生——请求帮助,请你写一个程序,对于输入的一场比赛的数据v1,v2,t,s,l,预测该场比赛的结果。
输入格式
  输入只有一行,包含用空格隔开的五个正整数v1,v2,t,s,l,其中(v1,v2<=100;t<=300;s<=10;l<=10000且为v1,v2的公倍数)
输出格式
  输出包含两行,第一行输出比赛结果——一个大写字母“T”或“R”或“D”,分别表示乌龟获胜,兔子获胜,或者两者同时到达终点。
  第二行输出一个正整数,表示获胜者(或者双方同时)到达终点所耗费的时间(秒数)。
样例输入
10 5 5 2 20
样例输出
D
4
样例输入
10 5 5 1 20
样例输出
R
3
样例输入
10 5 5 3 20
样例输出
T
4

答案:

import java.util.Scanner;

public class Main
{
    public static void main(String[] args)
    {
        Scanner in = new Scanner(System.in);
//      输入兔子的速度v1(表示每秒兔子能跑v1米),
//      乌龟的速度v2,以及兔子对应的t,s值,以及赛道的长度l
        int v1 = in.nextInt();
        int v2 = in.nextInt();
        int t = in.nextInt();
        int s = in.nextInt();
        int l = in.nextInt();
//      Rl是兔子跑过的长度;Tl是乌龟跑过的长度;i是秒数
        int Rl = 0, Tl = 0, i = 1;
//      当兔子和乌龟都没有到达终点时,两个就一直跑,只要有一方到达或超过终点,就结束,退循环
        while (Rl < l && Tl < l)
        {//这里的速度并不是物理上的那种速度,这里的速度相当于一段距离,
//      只要总路程加了一个单位的距离,总时间就也要加上一个单位的时间;这样处理后,就相当于物理上的速度了。           
//      跑一个单位的距离,时间也要相应地加一个单位
            Rl += v1;
            Tl += v2;
//          跑了一个单位后,看看兔子是否领先t米或以上
//          当然这里,有一个隐藏条件:这里的休息时间是兔子在领先而且没有到达终点时,才累计的
//          若跑了一个单位后,兔子领先但已经到达或超过终点了,那么兔子的休息时间就不用累计了
//          保险起见,确保双方都没到达终点。
            if (Rl - Tl >= t && Rl < l && Tl < l)
            {
//              在累计兔子的休息时间时,乌龟还在跑,时间+s;乌龟的路程+v2 * s。
                Tl += v2 * s;
                i += s;
            }   
            i++;        
        }

        i--;// 上面多加了一次 在这减去;这个是试出来的啦,,
//      通过比路程,来确定获胜者
        if (Rl >= l && Tl < l)
        {
            System.out.println("R");
            System.out.println(i);
        }
        else if (Rl < l && Tl >= l)
        {
            System.out.println("T");
            System.out.println(i);
        }
        else if (Rl >= l && Tl >= l)
        {
            System.out.println("D");
            System.out.println(i);
        }
    }
}

猜你喜欢

转载自blog.csdn.net/qq_37905259/article/details/80596317