当前位置:   article > 正文

龟兔赛跑_乌龟与兔子进行赛跑,跑场是一个矩型跑道,跑道边可以随地进行休息。乌龟每分钟可以

乌龟与兔子进行赛跑,跑场是一个矩型跑道,跑道边可以随地进行休息。乌龟每分钟可以

龟兔赛跑

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

  • 输入格式:

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

  • 输出格式:

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

  • 输入样例:
242
  • 1
  • 输出样例:
@_@ 726
  • 1
#include <stdio.h>

int judge(int n) {
	return ((n % 4 == 0 && n % 100 != 0) || n % 400 == 0);
}
int main() {
	int T;
	scanf("%d", &T);
	int check[1010] = {0};
	int gui[1010] = {0}, tu[1010] = {0};
	for (int i = 1; i < 1010; ++i) gui[i] = gui[i - 1] + 10 * 3;
	for (int i = 1; i < 1010; ++i) {
		tu[i] = tu[i - 1] + 10 * 9;
		if (tu[i] > gui[i]) {
			tu[i + 1] = tu[i + 2] = tu[i + 3] = tu[i];
			i += 3;
			check[i + 1] = check[i + 2] = check[i + 3] = 1;
		}
	}
	int k = T / 10;
	T %= 10;
	int t = tu[k];
	int g = gui[k];
	g += T * 3;
	if (!check[k]) t += T * 9;
	if (t < g) printf("@_@ %d\n", g);
  else {
    if (t == g) printf("-_- %d\n", g);
    else printf("^_^ %d\n", t);
  }
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/64430
推荐阅读
相关标签
  

闽ICP备14008679号