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