PTA 7-22 龟兔赛跑 C++

题目:

乌龟与兔子进行赛跑,跑场是一个矩型跑道,跑道边可以随地进行休息。乌龟每分钟可以前进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),再考虑少数的特殊情况(兔子停下来休息)

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hz2.0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值