PTA:7-22 龟兔赛跑 (20分)

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

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

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

输入样例:

242

输出样例:

@_@ 726

编程题被我做成了数学题:

#include <stdio.h>

int main()
{
	int T;
	scanf("%d", &T);
	int t = T;
	while ( T>90)
	{
		T = T-90;
	}
	//平局 
	if ( (T==0) || (T==30) || (T==45 )|| (T==60) || (T==90))
	{
		printf("-_- %d\n", 3*t);
	}
	//兔子赢(比较复杂) 
	if ( T>0&&T<10 ) //跑赢 
	{
		printf("^_^ %d\n", t/90*270+9*T); 
	}
	if ( T>=10&&T<30 ) //躺赢 
	{
		printf("^_^ %d\n", t/90*270+90);
	}
	if ( T>45&&T<50 ) //跑赢 
	{
		printf("^_^ %d\n", t/90*270+135+(T-45)*9);
	}
	if ( T>=50&&T<60 ) //躺赢
	{
		printf("^_^ %d\n", t/90*270+180);
	}
	//乌龟赢 
	if ( (T>30&&T<45) || (T>60&&T<90))
	{
		printf("@_@ %d\n", 3*t);
	}
	return 0;
}

网上看到的较好的解法:

以下代码中需注意判断语句中包含了自增自减操作;
使用编译器进行单步调试可促进对代码的理解。

#include <stdio.h>
int main ()
{
    int rab=0, tur=0, min, rest=-1, run=10; 
    //rab是兔子的路程,tur是乌龟的路程,min是比赛时间
    //rest是兔子还要休息的时间,run是兔子还要跑的时间 
    scanf ("%d",&min) ; 
    while(min--)
	{
        tur += 3;
        if (run-- > 0)  //注意即使条件不满足,此语句也会改变run的值
        {
        	rab += 9;
	    } 
        if (run == 0 )
		{           
            if (rab > tur && rest != 0) 
			{
				rest = 30;//条件满足,休息30分钟
				//注意,此条件结构进入一次后,run == 0;
				//由于上面的if (run-- > 0) 每次都会改变run的值
				//因此,休息时if (run == 0 )始终不成立,不会再次进入此语句
			}
			else
			{
				run = 10;//条件不满足,继续跑10分钟
		    }      
        }
        if (rest-- == 0) //休息结束,继续跑十分钟
        {
        	 run = 10;
		}                
    }
    if(tur > rab)
    {
    	printf("@_@ %d",tur);
	}
    else if (rab > tur)
    {
    	 printf("^_^ %d",rab);
	}
    else 
    {
    	printf("-_- %d",rab);
	} 
    return 0 ;
}
发布了54 篇原创文章 · 获赞 100 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/weixin_43871127/article/details/104316317