7-22 龟兔赛跑

文章描述了一个基于龟兔赛跑故事的编程问题,其中涉及两个角色的速度、休息时间和距离计算。兔子每10分钟会检查一次与乌龟的距离,如果领先则休息30分钟,而乌龟一直奔跑。程序通过循环计算在给定时间T分钟后,乌龟和兔子各自跑了多少距离,以确定赢家。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

龟兔赛跑

乌龟与兔子进行赛跑,跑场是一个矩型跑道,跑道边可以随地进行休息。乌龟每分钟可以前进3米,兔子每分钟前进9米;兔子嫌乌龟跑得慢,觉得肯定能跑赢乌龟,于是,每跑10分钟回头看一下乌龟,若发现自己超过乌龟,就在路边休息,每次休息30分钟,否则继续跑10分钟;而乌龟非常努力,一直跑,不休息。假定乌龟与兔子在同一起点同一时刻开始起跑,请问T分钟后乌龟和兔子谁跑得快?

输入格式:

输入在一行中给出比赛时间T(分钟)。

输出格式:

在一行中输出比赛的结果:乌龟赢输出@_@,兔子赢输出^_^,平局则输出-_-;后跟1空格,再输出胜利者跑完的距离。

输入样例:

242

输出样例:

@_@ 726

思路分析:

问题:

  1. 如何计算兔子跑的距离和乌龟跑的距离;计算兔子和乌龟分别跑的时间;
  2. 如何判断兔子是否再休息;
  3. 兔子休息的条件是什么;

解决:

  1. 理清楚(关键点):乌龟一直在跑;兔子除了休息就在跑;距离=速度*各自跑的时间;
  2. 设置一个sleep变量,来表示兔子休息的时间,休息时兔子不跑;
  3. 兔子跑的比乌龟多;此时兔子不在休息(sleep==0);每十分钟检查一次;

实现代码:

int main(){
    int sumT = 0;   //兔子跑的路程
    int sumG = 0;   //乌龟跑的路程
    int time;
    int sleep;      //兔子休息时间
    int timeS;      //输入时间
    scanf("%d", &timeS);
   for(time = 0;time < timeS;time++){
         sumG +=3;  //乌龟一直跑
        if(sumT > sumG && time%10==0 && sleep==0){  //满足1.兔子跑的多;
            sleep = 30;                            //2.每十分钟检查一次;
        }                                          //3.当前兔子不在休息;则让兔子休息30min
       
        if(sleep == 0)  //兔子不休息就在跑步
            sumT +=9;
        else            //兔子还在休息
            sleep--;
   }
    
    if(sumT > sumG)     //判断时间结束水跑的多
        printf("^_^ %d",sumT);
    else if(sumT < sumG)
        printf("@_@ %d",sumG);
    else
        printf("-_- %d",sumT);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值