乌龟与兔子进行赛跑,跑场是一个矩型跑道,跑道边可以随地进行休息。乌龟每分钟可以前进3米,兔子每分钟前进9米;兔子嫌乌龟跑得慢,觉得肯定能跑赢乌龟,于是,每跑10分钟回头看一下乌龟,若发现自己超过乌龟,就在路边休息,每次休息30分钟,否则继续跑10分钟;而乌龟非常努力,一直跑,不休息。假定乌龟与兔子在同一起点同一时刻开始起跑,请问T分钟后乌龟和兔子谁跑得快?
输入格式:
输入在一行中给出比赛时间T(分钟)。
输出格式:
在一行中输出比赛的结果:乌龟赢输出@_@
,兔子赢输出^_^
,平局则输出-_-
;后跟1空格,再输出胜利者跑完的距离。
输入样例:
242
输出样例:
@_@ 726
测试点二没有过去 ,不知为何
#include<stdio.h>
int main()
{
int t;
scanf("%d",&t);
int bie=0,rb=0;//老鳖总共走的路程
int i;
while(i<=t)
{
if(i%10==0)
{
if(rb>bie){
//休息三十分钟
i+=30;
if(i>=t){
bie+=3*(30-(i-t));//兔睡觉时鳖走的路 ,同时赢了
break;
}
else{
bie+=3*30;//兔睡觉时走的路
continue;
}
}
if(rb<bie)
{
//跑十分钟
i+=10;
if(i>=t)
{//不足十分钟
rb+=9*(10-(i-t));
bie+=3*(10-(i-t));
break;
}
else{
rb+=9*10;
bie+=3*10;
continue;//跑完后需要立刻回头看看
}
}
}
i++;
rb+=9;
bie+=3;
}
if(rb>bie) printf("^_^ %d\n",rb);
else if(rb==bie) printf("-_- %d\n",rb);
else printf("@_@ %d\n",bie);
}
下面是转载自https://blog.csdn.net/qq_43788669/article/list/1?t=1&
方法很简单,老鳖始终跑,就让它全程跑,计算兔的休息时间,如果不在休息时间就让兔跑
#include<stdio.h>
int main()
{
//time是兔子休息的时间;
int n,i,j,bie=0,rb=0,time=0,t;//bie是乌龟的路程,rb使兔子的路程;
scanf("%d",&t);
for(i=0;i<t;i++)
{
bie=bie+3;
if(time==0&&i%10==0&&rb>bie)
{
time=30;
}
if(time==0)
{
rb=rb+9;
}
else time--;
}
if(bie>rb) printf("@_@ %d",bie);
else if(bie<rb) printf("^_^ %d",rb);
else if(bie==rb) printf("-_- %d",bie);
return 0;
}