胎压监测问题

让我们把四个车轮 —— 左前轮、右前轮、右后轮、左后轮 —— 顺次编号为 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!
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{
 int arr[6] = {0};//六个值用数组接收
 scanf("%d%d%d%d%d%d", arr,arr+1,arr+2,arr+3,arr+4,arr+5);
 int j = 0;
 for (int i = 0; i < 6; i++)    //确定所有的数值都在0到400
 {
  if (((arr[i] <= 400) && (arr[i] >= 0))==0)
   j++;
 }
 if (j == 0)  //0到400成立
 {
  int max = arr[0];
  for (int i = 0; i < 4; i++)  //找出四个车轮压力最大值
  {
   if (arr[i + 1] > max)
    max = arr[i + 1];
  }
  int n = 0;//用于记录故障数量
  int jilu;  
  for (int i = 0; i < 4; i++)
  {
   if (arr[i] != max)
   {
    if (((max - arr[i]) > arr[5]) || (arr[i] < arr[4]))
     //差值小于最大阈值并保证大于最低压力,
    {
     n++;//记录故障车胎数
     jilu = i;//记录故障车胎
    }
   }
  }
  if (1 == n)//一个故障
   printf("Warning: please check #%d!", jilu+1);
  //由于jilu为数组下标,所以+1
  else if (n >= 2)//多个故障
   printf("Warning: please check all the tires!");
  else if (0 == n)//无故障
   printf("Normal");
 }
 return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

「 25' h 」

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

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

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

打赏作者

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

抵扣说明:

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

余额充值