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

题目

给你一个数组 time ,其中 time[i] 表示第 i 辆公交车完成 一趟 旅途 所需要花费的时间。

每辆公交车可以 连续 完成多趟旅途,也就是说,一辆公交车当前旅途完成后,可以 立马开始 下一趟旅途。每辆公交车 独立 运行,也就是说可以同时有多辆公交车在运行且互不影响。

给你一个整数 totalTrips ,表示所有公交车 总共 需要完成的旅途数目。请你返回完成 至少 totalTrips 趟旅途需要花费的 最少 时间。

思路

代码

java 复制代码
class Solution {
    public long minimumTime(int[] time, int totalTrips) {
        int minT = Integer.MAX_VALUE;
        for (int t : time) {
            minT = Math.min(minT, t);
        }
        long left = minT - 1; // 循环不变量:check(left) 恒为 false
        long right = (long) minT * totalTrips; // 循环不变量:check(right) 恒为 true
        while (left + 1 < right) { // 开区间 (left, right) 不为空
            long mid = (left + right) >>> 1;
            if (check(mid, time, totalTrips)) {
                right = mid; // 缩小二分区间为 (left, mid)
            } else {
                left = mid; // 缩小二分区间为 (mid, right)
            }
        }
        // 此时 left 等于 right-1
        // check(left) = false 且 check(right) = true,所以答案是 right
        return right; // 最小的 true
    }

    private boolean check(long x, int[] time, int totalTrips) {
        long sum = 0;
        for (int t : time) {
            sum += x / t;
            if (sum >= totalTrips) {
                return true;
            }
        }
        return false;
    }
}

性能

相关推荐
fengfuyao98515 小时前
基于STM32的4轴步进电机加减速控制工程源码(梯形加减速算法)
网络·stm32·算法
无敌昊哥战神16 小时前
深入理解 C 语言:巧妙利用“0地址”手写 offsetof 宏与内存对齐机制
c语言·数据结构·算法
小白菜又菜16 小时前
Leetcode 2075. Decode the Slanted Ciphertext
算法·leetcode·职场和发展
Proxy_ZZ016 小时前
用Matlab绘制BER曲线对比SPA与Min-Sum性能
人工智能·算法·机器学习
黎阳之光16 小时前
黎阳之光:以视频孪生领跑全球,赋能数字孪生水利智能监测新征程
大数据·人工智能·算法·安全·数字孪生
小李子呢021117 小时前
前端八股6---v-model双向绑定
前端·javascript·算法
前端大波17 小时前
前端面试通关包(2026版,完整版)
前端·面试·职场和发展
2301_8227032018 小时前
Flutter 框架跨平台鸿蒙开发 - 创意声音合成器应用
算法·flutter·华为·harmonyos·鸿蒙
zhaoshuzhaoshu18 小时前
人工智能(AI)发展史:详细里程碑
人工智能·职场和发展
cmpxr_18 小时前
【C】数组名、函数名的特殊
c语言·算法