天梯赛 L1-069 胎压监测 (15 分)

天梯赛 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;
}

感悟

  • 审题仔细,要充分理解题意啊。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值