7-? 鳖兔赛跑

乌龟与兔子进行赛跑,跑场是一个矩型跑道,跑道边可以随地进行休息。乌龟每分钟可以前进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;
}

猜你喜欢

转载自blog.csdn.net/weixin_43938351/article/details/89466875