【LeetCode】2187. 完成旅途的最少时间

1. 题意

2. 分析

二分法有一个关键特征:如果答案answer满足题意,那么对于任何整数i,如果有i>=answer,那么i也会是一个存在的解,只不过不是最优解。

本题想要找出一个达到 totalTrips 趟需要的最少时间成本t,那么对于题目来说任何大于t的数也会是解,但不是最优解;任何小于t的数都不是解。这样整个值域就被分成了两部分,区间[0,t)[t, +∞),如下图所示:

那么使用二分法不断的折中找出这个边界值即可。

3. 代码

python 复制代码
class Solution:
    def minimumTime(self, time: List[int], totalTrips: int) -> int:
        left = 1
        max_time = time[0]
        for cur_time in time:
            max_time = max(max_time, cur_time)
        
        # 如果由这辆最慢的车完成totalTrips 需要的时间
        right = max_time * totalTrips
        while(left <= right):
            mid = (left+right)//2
            if self.check(mid, totalTrips, time):
                right = mid-1
            else:
                left = mid+1
        return left
            
    # time_cost 需要花费的最少时间
    # times 时间数组
    def check(self, time_cost, totalTrips, times):
        cnt = 0
        for time in times:
            cnt += (time_cost//time) # 当前这个time可以完成几趟
        return cnt >= totalTrips
相关推荐
hetao173383712 分钟前
2025-12-12~14 hetao1733837的刷题笔记
数据结构·c++·笔记·算法
鲨莎分不晴1 小时前
强化学习第五课 —— A2C & A3C:并行化是如何杀死经验回放
网络·算法·机器学习
搞科研的小刘选手2 小时前
【ISSN/ISBN双刊号】第三届电力电子与人工智能国际学术会议(PEAI 2026)
图像处理·人工智能·算法·电力电子·学术会议
拉姆哥的小屋2 小时前
从混沌到秩序:条件扩散模型在图像转换中的哲学与技术革命
人工智能·算法·机器学习
Sammyyyyy2 小时前
DeepSeek v3.2 正式发布,对标 GPT-5
开发语言·人工智能·gpt·算法·servbay
sin_hielo3 小时前
leetcode 2110
数据结构·算法·leetcode
Jay20021113 小时前
【机器学习】33 强化学习 - 连续状态空间(DQN算法)
人工智能·算法·机器学习
panzer_maus3 小时前
归并排序的简单介绍
java·数据结构·算法
cici158744 小时前
二值化断裂裂缝的智能拼接算法
人工智能·算法·计算机视觉
麦格芬2304 小时前
LeetCode 763 划分字母区间
算法·leetcode·职场和发展