华为OD统一考试 - 运输时间

题目描述

M 辆车需要在一条不能超车的单行道到达终点,起点到终点的距离为 N

速度快的车追上前车后,只能以前车的速度继续行驶,求最后一车辆到达目的地花费的时间。

注意:

每辆车固定间隔 1 小时出发,比如第一辆车 0 时出发,第二辆车 1 时出发,依次类推。

输入描述

第一行两个数字: M 、 N,分别代表车辆数和到终点的距离,以空格分隔。

接下来 M 行,每行 1 个数字 S , 代表每辆车的速度。

  • 1 ≤ M ≤ 20
  • 1 ≤ N ≤ 400
  • 0 < S < 30

输出描述

最后一辆车到达目的地花费的时间。

示例1

输入:
2 11
3
2

输出:
5.5

说明:
2 辆车,距离 11 ,0 时出发的车速度快,1 时出发的车,达到目的地花费 5.5 。

题解

该问题涉及到车辆在单行道上行驶,不能超车,每辆车按照固定间隔出发,且速度较快的车追上前车后只能以前车的速度行驶。我们需要计算最后一辆车到达目的地所需的时间

思路:

  1. 读取输入的车辆数 M 和到终点的距离 N。
  2. 使用一个循环读取每辆车的速度,并计算该车到达目的地的时间
  3. 在计算过程中,记录最后一辆车到达目的地最晚的时间。
  4. 最后,输出最后一辆车到达目的地花费的时间

该问题的关键点是在计算每辆车到达目的地的时间时,要考虑可能的阻塞情况,即后面的车可能会追上前车。

因此,要取每辆车到达时间的最大值。最后输出最后一辆车到达目的地花费的时间即可。


import Foundation

func ODTest_2_7() {
    print("第一行两个数字: M 、 N,分别代表车辆数和到终点的距离,以空格分隔。")
    let MN = (readLine() ?? "").split(separator: " ").map { Int($0) ?? 0 }
    if MN.count != 2 {
        print("NULL")
        return
    }
    let M = MN[0]
    let N = Double(MN[1])
    if M < 1 || M > 20 || N < 1 || N > 400 {
        print("NULL")
        return
    }
    print("接下来 M 行,每行 1 个数字 S , 代表每辆车的速度。")
    var speeds: [Double] = []
    for _ in 0 ..< M {
        let speed = Double(readLine() ?? "") ?? 0
        if speed < 1 || speed > 30 {
            print("NULL")
            return
        }
        speeds.append(speed)
    }
    print("输出描述")
    print("最后一辆车到达目的地花费的时间。")

    var speed = speeds[0]
    for i in 1 ..< M {
        if (N / speeds[i] + 1) > (N / speed) {
            speed = speeds[i]
        } else {
            speeds[i] = speed
        }
    }
    print("\(N / speed)")
}

全部评论

相关推荐

点赞 1 评论
分享
牛客网
牛客企业服务