7-22 龟兔赛跑(分数 20)

本文探讨了乌龟和兔子在设定条件下,利用计时和策略差异的比赛结果。兔子因频繁休息而影响速度,乌龟坚持不懈。通过算法模拟,揭示谁在T分钟后领先。

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

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

输入格式:

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

输出格式:

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

样例:">样例:">样例:">样例:">样例:">样例:">输入样例:

242

输出样例:

@_@ 726

问题分析

每跑十分钟后要判断兔子是否在前,时间不够10分钟就跑完剩余时间,如果在前那么接下来三十分钟兔子不跑乌龟跑,时间不够30分钟,就跑完剩余时间。在while循环中循环条件为shijian<t,这样可以保证跑的时间是t分钟。

代码实现 

#include<stdio.h>
int main(){
    int t;
    scanf("%d",&t);
    int shijian=0,gui=0,tu=0;
    while(shijian<t){
        if(tu>gui){
            if(t-shijian>30){
                shijian+=30;
                gui+=30*3;
            }else{
                gui+=(t-shijian)*3;
                shijian+=t-shijian;
            }
        }else{
            if(t-shijian>10){
                tu+=9*10;
                gui+=3*10;
                shijian+=10;
            }else{
                tu+=9*(t-shijian);
                gui+=3*(t-shijian);
                shijian=t;
            }
        }
    }
    if(tu>gui){
        printf("^_^ %d",tu);
    }else if(gui>tu){
        printf("@_@ %d",gui);
    }else if(gui==tu){
        printf("-_- %d",gui);
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值