博主不定期更新【保研/推免、C/C++、5G移動通信、Linux、生活隨筆】系列文章,喜歡的朋友【點贊+關注】支持一下吧!
烏龜與兔子進行賽跑,跑場是一個矩型跑道,跑道邊可以隨地進行休息。烏龜每分鐘可以前進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 ;
}