题目:
乌龟与兔子进行赛跑,跑场是一个矩型跑道,跑道边可以随地进行休息。乌龟每分钟可以前进3米,兔子每分钟前进9米;兔子嫌乌龟跑得慢,觉得肯定能跑赢乌龟,于是,每跑10分钟回头看一下乌龟,若发现自己超过乌龟,就在路边休息,每次休息30分钟,否则继续跑10分钟;而乌龟非常努力,一直跑,不休息。假定乌龟与兔子在同一起点同一时刻开始起跑,请问T分钟后乌龟和兔子谁跑得快?
输入格式:
输入在一行中给出比赛时间T(分钟)。
输出格式:
在一行中输出比赛的结果:乌龟赢输出@_@
,兔子赢输出^_^
,平局则输出-_-
;后跟1空格,再输出胜利者跑完的距离。
输入样例:
242
输出样例:
@_@ 726
代码:
#include<iostream>
using namespace std;
int main()
{
int T, s1 = 0, s2 = 0, t;//s1、s2分别表示兔子、乌龟在t时刻运动距离
cin >> T;
//将问题过程化(分析过程)
for (t = 1; t <= T; t++) {
s1 = s1 + 9;
s2 = s2 + 3;
//当且仅当时间在整10并且s1>s2时,兔子会停下休息
if (t % 10 == 0 && s1 > s2) {
//剩余时间大于30min
if (T - t >= 30) {
t += 30;
s2 += 90;
}
//剩余时间小于30min
else
{
s2 += (T - t) * 3;
break;//跳出循环
}
}
}
//输出
if (s1 - s2 > 0)
printf("^_^ %d", s1);
else if (s2 == s1)
printf("-_- %d", s2);
else
printf("@_@ %d", s2);
return 0;
}
收获:
1.
将问题过程化,从t=1开始一直到t=T。
2.
写代码分析情况时,先考虑普通的大多数情况(s1 =s1+9; s2 = s2 + 3),再考虑少数的特殊情况(兔子停下来休息)