华为OD机试D卷C卷 - 单行道汽车通行时间/ 运输时间( Java题解)

本文提供了一道华为OD机试C卷中的编程题,涉及汽车在单行道上的通行时间计算。题目要求计算M辆速度不等的汽车在不能超车的情况下,最后一辆车达到终点所需的时间。每辆车按固定间隔出发,速度快的车追上慢车后需与其保持相同速度。解题思路和Java代码实现包括多个测试用例。
摘要由CSDN通过智能技术生成

题目描述

M(1<=M<=20)辆车需要在一条不能超车的单行道到达终点,起点到终点的距离为N(1<=N<=400)。速度快的车追上前车后,只能以前车的速度继续行驶。求最后一车辆到达目的地花费的时间。

注:每辆车固定间隔一小时出发,比如第一辆车0时出发,第二辆车1时出发,以此类推

输入描述

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

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

输出描述

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

用例

输入

2 11
3
2

输出

5.5

解题思路

参考代码注释

!!!

请注意,本题的答案可能是小数。由于题目未指定保留小数点后几位,我的代码就只根据用例1的格式四舍五入输出1位小数。 实际考试中,请根据情况以及具体要求调整。

Java

import java.util.*;

public class Main {
   
    public static void main(String[] args) 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

算法大师

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

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

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

打赏作者

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

抵扣说明:

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

余额充值