天梯赛 L1-069 胎压监测 (15 分)
题目
小轿车中有一个系统随时监测四个车轮的胎压,如果四轮胎压不是很平衡,则可能对行车造成严重的影响。

让我们把四个车轮 —— 左前轮、右前轮、右后轮、左后轮 —— 顺次编号为 1、2、3、4。本题就请你编写一个监测程序,随时监测四轮的胎压,并给出正确的报警信息。报警规则如下:
- 如果所有轮胎的压力值与它们中的最大值误差在一个给定阈值内,并且都不低于系统设定的最低报警胎压,则说明情况正常,不报警;
- 如果存在一个轮胎的压力值与它们中的最大值误差超过了阈值,或者低于系统设定的最低报警胎压,则不仅要报警,而且要给出可能漏气的轮胎的准确位置;
- 如果存在两个或两个以上轮胎的压力值与它们中的最大值误差超过了阈值,或者低于系统设定的最低报警胎压,则报警要求检查所有轮胎。
输入格式:
输入在一行中给出 6 个 [0, 400] 范围内的整数,依次为 1~4 号轮胎的胎压、最低报警胎压、以及胎压差的阈值。
输出格式:
根据输入的胎压值给出对应信息:
- 如果不用报警,输出
Normal; - 如果有一个轮胎需要报警,输出
Warning: please check #X!,其中X是出问题的轮胎的编号; - 如果需要检查所有轮胎,输出
Warning: please check all the tires!。
测试样例
输入样例1:
242 251 231 248 230 20
输出样例1:
Normal
输入样例2:
242 251 232 248 230 10
输出样例2:
Warning: please check #3!
输入样例3:
240 251 232 248 240 10
输出样例3:
Warning: please check all the tires!
简单分析:
- 感觉自己好笨,读题读半天。。。
- 注意里面的潜在关系,最大误差阈值与最低报警胎压两者是同步的,即在一个输入样例中只可能出现一种情况
代码:
#include <iostream>
#include <algorithm>
using namespace std;
int main() {
int maxx = -1;
int f[5];
for (int i = 1; i <= 4; i++) {
cin >> f[i];
maxx = max(maxx, f[i]);
}
int a, b;
cin >> a >> b;
int cnt = 0, pos = 0;
for (int i = 1; i <= 4; i++)
if (maxx - f[i] > b || f[i] < a) {
cnt++;
pos = i;
}
if (!cnt) puts("Normal");
else if (cnt == 1) printf("Warning: please check #%d!", pos);
else puts("Warning: please check all the tires!");
return 0;
}
感悟
- 审题仔细,要充分理解题意啊。
该博客讨论了一个小轿车胎压监测系统的重要性,详细解释了报警规则:当所有轮胎胎压在最大值一定误差范围内且不低于最低报警值时正常,否则会触发不同级别的警告。代码实现用于监测胎压并根据预设条件输出警告信息。
2928

被折叠的 条评论
为什么被折叠?



