【无标题】

题目名字 L1-069 胎压监测 (15 分)

[题目链接]https://pintia.cn/problem-sets/994805046380707840/problems/1336215880692482052

题意

小轿车中有一个系统随时监测四个车轮的胎压,如果四轮胎压不是很平衡,则可能对行车造成严重的影响。让我们把四个车轮 —— 左前轮、右前轮、右后轮、左后轮 —— 顺次编号为 1、2、3、4。本题就请你编写一个监测程序,随时监测四轮的胎压,并给出正确的报警信息。报警规则如下:
1.如果所有轮胎的压力值与它们中的最大值误差在一个给定阈值内,并且都不低于系统设定的最低报警胎压,则说明情况正常,不报警;
2.如果存在一个轮胎的压力值与它们中的最大值误差超过了阈值,或者低于系统设定的最低报警胎压,则不仅要报警,而且要给出可能漏气的轮胎的准确位置;
3.如果存在两个或两个以上轮胎的压力值与它们中的最大值误差超过了阈值,或者低于系统设定的最低报警胎压,则报警要求检查所有轮胎。
输入格式:
输入在一行中给出 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!

思路

  1. 首先用数组存储四个轮胎的胎压,然后遍历找出四个中的最大值;
  2. 需要计算轮胎最大误差值;
  3. 然后再计算有多少个低于给定的胎压值;

坑点

  1. 需要保存轮胎的编号

实现步骤
  1. 首先用数组存储四个轮胎的胎压,然后遍历找出四个中的最大值;
  2. 然后再定义三个值,分别对需要报警的轮胎和不需要报警的轮胎进行计数,并且定义保存轮胎的编号;
  3. 判断是否需要报警的轮胎;
    4.分别判断情况;
代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
    int p[5]={0},minP,range;
    cin>>p[1]>>p[2]>>p[3]>>p[4]>>minP>>range;
    int max=0;
    for(int i=1;i<=4;i++)
	{
        if(p[i]>max)
		{
            max=p[i];//找出最大值
        }
    }
    int count1=0,count2=0,index;//用count1对不需要报警的轮胎进行计数,用count2对需要报警的轮胎进行计数同时使用index保存轮胎编号(数组下标);
    for(int i=1;i<=4;i++)
	{
        int e=max-p[i];//计算最大值和其他轮胎的差值; 
        if(e<=range&&p[i]>=minP)
		{
            count1++;
        }
        if(e>range||p[i]<minP)
		{
            count2++;
            index=i;//保存轮胎编号
        }
    }
    if(count1==4)//如果所有都不满足报警条件; 
	{ 
        cout<<"Normal";
        return 0;
    }
    if(count2==1)//如果存在一个满足报警条件; 
	{ 
        cout<<"Warning: please check #"<<index<< "!";
    }
	else//如果存在两个或两个以上满足报警条件 ; 
	{ 
        cout<<"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、付费专栏及课程。

余额充值