24小时热门版块排行榜    

CyRhmU.jpeg
查看: 1441  |  回复: 2

sc1314

新虫 (初入文坛)

[求助] C语言高手请进,龟兔赛跑的问题!

龟兔赛跑预测
问题描述
话说这个世界上有各种各样的兔子和乌龟,但是研究发现,所有的兔子和乌龟都有一个共同的特点——喜欢赛跑。于是世界上各个角落都不断在发生着乌龟和兔子的比赛,小华对此很感兴趣,于是决定研究不同兔子和乌龟的赛跑。他发现,兔子虽然跑比乌龟快,但它们有众所周知的毛病——骄傲且懒惰,于是在与乌龟的比赛中,一旦任一秒结束后兔子发现自己领先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”,分别表示乌龟获胜,兔子获胜,或者两者同时到达终点。 第二行输出一个正整数,表示获胜者(或者双方同时)到达终点所耗费的时间(秒数)。

样例输入
Sample 1
10 5 5 2 20

Sample2
10 5 5 1 20

Sample3
10 5 5 3 20

样例输出
Sample1
D
4

Sample2
R
3

Sample3
T
4
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

capital_j

木虫 (小有名气)

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
jjdg: 金币+2, 感谢应助 2012-04-02 03:36:29
#include
using namespace std;

void func(int rubspeed,int turspeed,int t,int s,int l,int a[])
{
    int sleeptime = 0;
    a[0]=a[1]=a[2]=0;
    while(1)
    {
        if(sleeptime){
            sleeptime--;
        }
        else {
            if(a[1]-a[2]>=t) sleeptime = s-1;
            else a[1]+=rubspeed;
        }
        a[2]+=turspeed;
        a[0]++;
        if(a[1]>=l || a[2]>=l) return;
   }
}
int main()
{
    int a1=10,a2=5,a3=5,a4=2,a5=20;
    int a[3]={0,0,0};//记录到达终点时a[0]时间 a[1]兔子已跑 a[2]乌龟已跑
    while(a1)
    {
        cin>>a1>>a2>>a3>>a4>>a5;
        func(a1,a2,a3,a4,a5,a);
        if(a[1]>=a5 && a[2]>=a5) cout<<"D";
        else{
            if(a[2]>=a5) cout<<"T";
            if(a[1]>=a5) cout<<"R";
        }
        cout<     }
    return 0;
}
验证,已通过
懒得改成c语言了,你主要看看思路。(也就是include和输出有点异样)
有些誓言,说了就不起作用了。有的人,见了却没有感觉了了。珍惜现在每一秒,不苛求将来。
2楼2012-04-01 22:28:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

emanlee

木虫 (小有名气)

【答案】应助回帖

★ ★ ★
感谢参与,应助指数 +1
jjdg: 金币+3, 感谢应助 2012-04-04 00:26:06
jjdg: 编辑内容 2012-04-04 00:26
jjdg: 编辑内容 2012-04-04 00:26
jjdg: 编辑内容 2012-04-04 00:26
以下为C语言版本:

#include "stdio.h"


void func(int rubspeed,int turspeed,int t,int s,int l,int a[])
{
    int sleeptime = 0;
    a[0]=a[1]=a[2]=0;
    while(1)
    {
        if(sleeptime){
            sleeptime--;
        }
        else {
            if(a[1]-a[2]>=t) sleeptime = s-1;
            else a[1]+=rubspeed;
        }
        a[2]+=turspeed;
        a[0]++;
        if(a[1]>=l || a[2]>=l) return;
   }
}
int main()
{
    int a1=10,a2=5,a3=5,a4=2,a5=20;
    int a[3]={0,0,0};/*记录到达终点时a[0]时间 a[1]兔子已跑 a[2]乌龟已跑 */
    while(a1)
    {
        
                scanf("%d%d%d%d%d",a1,a2,a3,a4,a5);
        func(a1,a2,a3,a4,a5,a);
        if(a[1]>=a5 && a[2]>=a5) printf("D" );
        else{
            if(a[2]>=a5) printf("T" );
            if(a[1]>=a5) printf("R" );
        }
        printf("\n%d\n",a[0]);

    }
    return 0;
}

[ Last edited by jjdg on 2012-4-4 at 00:26 ]
3楼2012-04-03 08:39:39
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 sc1314 的主题更新
信息提示
请填处理意见