运输时间 - 华为OD统一考试(C卷)

OD统一考试(C卷)

分值: 200分

题解: Java / Python / C++

alt

题目描述

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. 最后,输出最后一辆车到达目的地花费的时间

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

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

Java

import java.util.Scanner;

/**
 * @author code5bug
 */
public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        int M = scanner.nextInt();
        int N = scanner.nextInt();

        // 最后一辆车到达目的地最晚的时间
        double maxCostTime = 0;

        for (int waitTime = 0; waitTime < M; waitTime++) {
            int speed = scanner.nextInt();
            // 没有阻塞时,当前车到达目的地的时间是: N / speed + waitTime
            // 由于可能阻塞所以耗时只能取最大值
            maxCostTime = Math.max(maxCostTime, 1.0 * N / speed + waitTime);
        }

        // 需要排队,所以最后一辆成肯定最后到达终点
        // 因此, 最后一辆车到达目的地花费的时间 = maxCostTime - waitTime
        System.out.println(maxCostTime - M + 1);
    }
}

Python

M, N = map(int, input().split())

# 最后一辆车到达目的地最晚的时间
max_cost_time = 0
for wait_time in range(M):
    speed = int(input())
    # 没有阻塞时,当前车到达目的地的时间是:  N / speed + wait_time
    # 由于可能阻塞所以耗时只能取最大值
    max_cost_time = max(max_cost_time, N / speed + wait_time)

# 需要排队,所以最后一辆成肯定最后到达终点
# 因此, 最后一辆车到达目的地花费的时间 = max_cost_time - wait_time
print(max_cost_time - M + 1)

C++

#include <iostream>
#include <algorithm>

using namespace std;

int main() {
    // 读取输入
    int M, N;
    cin >> M >> N;

    // 最后一辆车到达目的地最晚的时间
    double maxCostTime = 0;

    for (int waitTime = 0; waitTime < M; waitTime++) {
        int speed;
        cin >> speed;
        // 没有阻塞时,当前车到达目的地的时间是: N / speed + waitTime
        // 由于可能阻塞所以耗时只能取最大值
        maxCostTime = max(maxCostTime, 1.0 * N / speed + waitTime);
    }

    // 需要排队,所以最后一辆成肯定最后到达终点
    // 因此, 最后一辆车到达目的地花费的时间 = maxCostTime - waitTime
    cout << maxCostTime - M + 1 << endl;

    return 0;
}

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

#面经##华为##春招##校招##秋招#
全部评论

相关推荐

面试官全程关摄像头1.自我介绍一下2.React和Vue哪个更熟悉一点3.你在之前那段实习经历中有没有什么技术性的突破(我只是实习了44天工作28天,我把我能说的都说了)4.你封装的哪个表单组件支不支持动态传值5.自己在实习阶段Vue3项目封装过hook吗6.hook有什么作用7.Vue2和Vue3的响应式区别(我说一个是proxy是拦截所有的底层操作,Object.defineProperty本身就是一个底层操作,有些东西拦截不了,比如数组的一些操作还有等等,面试官就说实在要拦截能不能拦截????我心想肯定不行呀,他的底层机制就不允许吧)8.pinia和vuex的区别(这个回答不出来是我太久没用了)9.pinia和zustand的区别,怎么选(直接给我干懵了)(我说react能用pinia吗&nbsp;&nbsp;他说要用的话也可以)10.渲染一万条数据,怎么解决页面卡顿问题(我说分页、监听滚轮动态加载,纯数据展示好像还可以用canvas画)(估计是没说虚拟表单,感觉不满意)11.type和interface的区别12.ts的泛型有哪些作用(我就说了一个结构相同但是类型不同的时候可以用,比如请求响应的接口,每次的data不同,这里能用一个泛型,他问我还有什么)13.你项目用的是React,如果让你再写一遍你会选择什么14.pnpm、npm、yarn的区别15.dependencies和devdependencies的区别总而言之太久没面试了,上一段实习的面试js问了很多。结果这次js一点没问,网络方面也没考,表现得很一般,但是知道自己的问题了&nbsp;&nbsp;好好准备,等待明天的影石360和周四的腾讯了&nbsp;&nbsp;加油!!!
解zj:大三的第一段面试居然是这样的结局
查看15道真题和解析
点赞 评论 收藏
分享
评论
4
4
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务