zoukankan      html  css  js  c++  java
  • 龟兔赛跑预测

    时间限制:1.0s   内存限制:512.0MB
       
     

    问题描述

      话说这个世界上有各种各样的兔子和乌龟,但是研究发现,所有的兔子和乌龟都有一个共同的特点——喜欢赛跑。
    于是世界上各个角落都不断在发生着乌龟和兔子的比赛,小华对此很感兴趣,于是决定研究不同兔子和乌龟的赛跑。他发现,
    兔子虽然跑比乌龟快,但它们有众所周知的毛病——骄傲且懒惰,于是在与乌龟的比赛中,一旦任一秒结束后兔子发现自
    己领先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

    源代码:

    package lanqiao;
    
    import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStreamReader;
    
    /**
    *@author wenfan
    *@version 2019年3月2日下午6:21:46
    */
    public class Guitusaipao {
        public static void main(String[] args) throws IOException {
            
            BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
            String [] var = br.readLine().split(" ");
            int v1 = Integer.parseInt(var[0]),
                v2 = Integer.parseInt(var[1]),
                t = Integer.parseInt(var[2]),
                s = Integer.parseInt(var[3]),
                l = Integer.parseInt(var[4]);
            int s1 = 0,s2 = 0,temp = 0,count=0;
            for(int i= 0;i <= (l/v2);i++) {
                if(s1 >= l || s2 >= l) {
                    break;
                }
                if(((s1-s2) >= t)) {
                    temp = s;
                    count++;
                }
                if((temp > 0)) {
                    s2 = s2 + v2;
                    temp--;
                }else {
                    s1 = s1 + v1;
                    s2 = s2 + v2;
                }
                
            }
            if(s1 > s2) {
                System.out.println("R");
                System.out.println((l/v1)+count*s);
            }else if(s1 == s2) {
                System.out.println("D");
                System.out.println(l/v2);
            }else {
                System.out.println("T");
                System.out.println(l/v2);
            }
            
        }
    }
  • 相关阅读:
    Codeforces Round #687 A. Prison Break
    最小生成树自用笔记(Kruskal算法+prim算法)
    Codeforces Round #686 (Div. 3)(A->D)(模拟,vector,数学)
    Acwing 852. spfa判断负环
    Linux内核分析_课程学习总结报告
    结合中断上下文切换和进程上下文切换分析Linux内核的一般执行过程
    深入理解系统调用
    基于mykernel 2.0编写一个操作系统内核
    何评测一个软件工程师的计算机网络知识水平与网络编程技能水平?——参考试题
    TCP三次握手Linux源码解析
  • 原文地址:https://www.cnblogs.com/outxiao/p/10462538.html
Copyright © 2011-2022 走看看