leetcode - 1870. Minimum Speed to Arrive on Time

Description

You are given a floating-point number hour, representing the amount of time you have to reach the office. To commute to the office, you must take n trains in sequential order. You are also given an integer array dist of length n, where disti describes the distance (in kilometers) of the ith train ride.

Each train can only depart at an integer hour, so you may need to wait in between each train ride.

For example, if the 1st train ride takes 1.5 hours, you must wait for an additional 0.5 hours before you can depart on the 2nd train ride at the 2 hour mark.

Return the minimum positive integer speed (in kilometers per hour) that all the trains must travel at for you to reach the office on time, or -1 if it is impossible to be on time.

Tests are generated such that the answer will not exceed 107 and hour will have at most two digits after the decimal point.

Example 1:

复制代码
Input: dist = [1,3,2], hour = 6
Output: 1
Explanation: At speed 1:
- The first train ride takes 1/1 = 1 hour.
- Since we are already at an integer hour, we depart immediately at the 1 hour mark. The second train takes 3/1 = 3 hours.
- Since we are already at an integer hour, we depart immediately at the 4 hour mark. The third train takes 2/1 = 2 hours.
- You will arrive at exactly the 6 hour mark.

Example 2:

复制代码
Input: dist = [1,3,2], hour = 2.7
Output: 3
Explanation: At speed 3:
- The first train ride takes 1/3 = 0.33333 hours.
- Since we are not at an integer hour, we wait until the 1 hour mark to depart. The second train ride takes 3/3 = 1 hour.
- Since we are already at an integer hour, we depart immediately at the 2 hour mark. The third train takes 2/3 = 0.66667 hours.
- You will arrive at the 2.66667 hour mark.

Example 3:

复制代码
Input: dist = [1,3,2], hour = 1.9
Output: -1
Explanation: It is impossible because the earliest the third train can depart is at the 2 hour mark.

Constraints:

复制代码
n == dist.length
1 <= n <= 10^5
1 <= dist[i] <= 10^5
1 <= hour <= 10^9
There will be at most two digits after the decimal point in hour.

Solution

Since speed is positive integer, and for each speed we know whether this speed can get us to the destination within give time or not, we could use binary search to find the optimal speed. Try to find the smallest speed that is valid.

To start searching, firstly we need to determine the search range. I used some maths to calculate the range, but actually use [1, 10^7] would be easier.

Time complexity: o ( log ⁡ n ) o(\log n) o(logn), where n ∈ 1 , 1 0 7 n \in 1, 10\^7 n∈1,107

Space complexity: o ( 1 ) o(1) o(1)

Code

python3 复制代码
class Solution:
    def is_valid(self, speed: int, dist: list, hour: float) -> bool:
        """
        Decide whether using this speed is valid or not
        """
        sum_of_time = 0
        for each_dist in dist[:-1]:
            sum_of_time += math.ceil(each_dist / speed)
        sum_of_time += dist[-1] / speed
        return True if sum_of_time <= hour else False


    def minSpeedOnTime(self, dist: List[int], hour: float) -> int:
        if hour - len(dist) + 1 <= 0:
            return -1

        import math
        left = max(math.floor(sum(dist) / hour), 1)
        right = max(max(dist), math.ceil(dist[-1] / (hour - len(dist) + 1)))
        while left < right:
            mid = (left + right) >> 1
            if not self.is_valid(mid, dist, hour):
                left = mid + 1
            else:
                right = mid
        mid = (left + right) >> 1
        if self.is_valid(mid, dist, hour):
            return mid
        return -1
相关推荐
春日见8 小时前
五分钟入门 强化学习---Q-Learning算法与实现
人工智能·python·深度学习·算法·机器学习·计算机视觉
Zldaisy3d9 小时前
全球唯一仿真驱动自适应扫描路径新版本发布,金属3D打印工艺开发进入算法时代
算法·3d
小江的记录本9 小时前
【JVM虚拟机】类加载机制:类加载全流程:加载→验证→准备→解析→初始化(附《思维导图》+《面试高频考点清单》)
java·jvm·spring boot·算法·安全·spring·面试
故事和你919 小时前
洛谷-【动态规划2】线性状态动态规划4
开发语言·数据结构·c++·算法·动态规划·图论
不吃土豆的马铃薯9 小时前
Socket 网络编程实战教程
linux·服务器·开发语言·网络·c++·算法
weixin_4684668510 小时前
图像滤波算法新手实战指南
图像处理·人工智能·算法·计算机视觉·ai·机器视觉·滤波
Ulyanov10 小时前
深入QML-Python通信 构建响应式交互界面的桥梁设计:QML+PySide6现代开发入门(五)
开发语言·python·算法·交互·qml·系统仿真
重生之我是Java开发战士10 小时前
【贪心算法】加油站,单调递增的数字,坏了的计算器,合并区间,用最少数量的箭引爆气球
算法·贪心算法
小欣加油10 小时前
leetcode 3300 替换为数位和后的最小元素
数据结构·c++·算法·leetcode
晚风予卿云月10 小时前
【枚举】普通枚举
数据结构·c++·算法·竞赛·算法随笔