L1-069 胎压监测 仓颉(cangjie)

L1-069 胎压监测

分数 15

作者 陈越

单位 浙江大学

小轿车中有一个系统随时监测四个车轮的胎压,如果四轮胎压不是很平衡,则可能对行车造成严重的影响。

taiya.JPG

让我们把四个车轮 —— 左前轮、右前轮、右后轮、左后轮 —— 顺次编号为 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!

仓颉(cjc) 

import std.console.*
import std.convert.*
import std.math.*

main(): Unit {
    let get: Array<String> = Console.stdIn.readln().getOrThrow().split(" ")
    var ty: Array<Int64> = Array<Int64>(4, item: 0)
    var max: Int64 = 0
    var min: Int64 = Int64.parse(get[4])
    var minCount: Int64 = 0
    var minIndex: Int64 = -1
    for (i in 0..4) {
        ty[i] = Int64.parse(get[i])
        if (max < ty[i]) {
            max = ty[i]
        }
        if (ty[i] < min) {
            minCount++
            minIndex = i
        }
    }

    var chaCount: Int64 = 0
    var chaIndex: Int64 = 0
    for (i in 0..4) {
        if (abs(max - ty[i]) > Int64.parse(get[5])) {
            chaCount++
            chaIndex = i
        }
    }

    if (minCount == 0 && chaCount == 0) {
        print("Normal")
    } else if (minCount == 0 && chaCount == 1) {
        print("Warning: please check #${chaIndex+1}!")
    } else if (minCount == 1 && chaCount == 0) {
        print("Warning: please check #${minIndex+1}!")
    } else if (minCount == 1 && chaCount == 1 && (chaIndex == minIndex)) {
        print("Warning: please check #${minIndex+1}!")
    } else {
        print("Warning: please check all the tires!")
    }
}

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值