LeetCode 2187. 完成旅途的最少时间(二分查找)
文章目录
- 1. 题目
- 2. 解题
1. 题目
给你一个数组 time ,其中 time[i] 表示第 i 辆公交车完成 一趟旅途 所需要花费的时间。
每辆公交车可以 连续 完成多趟旅途,也就是说,一辆公交车当前旅途完成后,可以 立马开始 下一趟旅途。
每辆公交车 独立 运行,也就是说可以同时有多辆公交车在运行且互不影响。
给你一个整数 totalTrips ,表示所有公交车 总共 需要完成的旅途数目。请你返回完成 至少 totalTrips 趟旅途需要花费的 最少 时间。
示例 1:
输入:time = [1,2,3], totalTrips = 5
输出:3
解释:
- 时刻 t = 1 ,每辆公交车完成的旅途数分别为 [1,0,0] 。已完成的总旅途数为 1 + 0 + 0 = 1 。
- 时刻 t = 2 ,每辆公交车完成的旅途数分别为 [2,1,0] 。已完成的总旅途数为 2 + 1 + 0 = 3 。
- 时刻 t = 3 ,每辆公交车完成的旅途数分别为 [3,1,1] 。已完成的总旅途数为 3 + 1 + 1 = 5 。
所以总共完成至少 5 趟旅途的最少时间为 3 。示例 2:
输入:time = [2], totalTrips = 1
输出:2
解释:
只有一辆公交车,它将在时刻 t = 2 完成第一趟旅途。
所以完成 1 趟旅途的最少时间为 2 。提示:
1 <= time.length <= 10^5
1 <= time[i], totalTrips <= 10^7
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/minimum-time-to-complete-trips
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
2. 解题
- 所花费的时间变多,能完成的总的 旅程 数量不会减少,具有单调性,对答案进行二分查找
typedef long long LL;
class Solution {public:long long minimumTime(vector<int>& time, int totalTrips) { LL l = 1, r = 1e15, mid, ans = r;while(l <= r){mid = (l+r)>>1;if(canfinish(time, totalTrips, mid)){ans = mid;r = mid-1;}elsel = mid+1;}return ans;}bool canfinish(vector<int>& time, int totalTrips, long long tottime){LL ct = 0;for(auto t : time){ct += tottime/t;if(ct >= totalTrips)return true;}return false;}
};
148 ms 86.6 MB C++
我的CSDN博客地址 https://michael.blog.csdn.net/
长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
LeetCode 2187. 完成旅途的最少时间(二分查找)相关推荐
- 力扣 6010. 完成旅途的最少时间
题目 给你一个数组 time ,其中 time[i] 表示第 i 辆公交车完成 一趟旅途 所需要花费的时间. 每辆公交车可以 连续 完成多趟旅途,也就是说,一辆公交车当前旅途完成后,可以 立马开始 下 ...
- [二分法]leetcode2187:完成旅途的最少时间(medium)
题目: 题解: 思路:二分法 关于如何想到使用二分时间t呢? 首先题目说的是给定一个时间 t,然后求每辆公交车可以在这个时间t内能完成的旅途数,用t/a[i]来表示第i辆公交车在时间t内能完成的旅途数 ...
- leetcode2187. 完成旅途的最少时间(mid)(282)
完成旅途的最少时间 代码 力扣链接 代码 class Solution {public long minimumTime(int[] time, int totalTrips) {long l = 1 ...
- LeetCode 1231. 分享巧克力(极小极大化 二分查找)
文章目录 1. 题目 2. 解题 1. 题目 你有一大块巧克力,它由一些甜度不完全相同的小块组成.我们用数组 sweetness 来表示每一小块的甜度. 你打算和 K 名朋友一起分享这块巧克力,所以你 ...
- LeetCode-完成旅途的最少时间
题目 给你一个数组 time ,其中 time[i] 表示第 i 辆公交车完成 一趟旅途 所需要花费的时间. 每辆公交车可以 连续 完成多趟旅途,也就是说,一辆公交车当前旅途完成后,可以 立马开始 下 ...
- LeetCode:数组(排列组合,二分查找I,二分查找II)
1,排列组合 38,剑指Offer:字符串的排列 题目:输入一个字符串,打印出该字符串中字符的所有排列.你可以以任意顺序返回这个字符串数组,但里面不能有重复元素. class Solution {Li ...
- LeetCode 1235. 规划兼职工作(动态规划+二分查找)
文章目录 1. 题目 2. 解题 1. 题目 你打算利用空闲时间来做兼职工作赚些零花钱. 这里有 n 份兼职工作,每份工作预计从 startTime[i] 开始到 endTime[i] 结束,报酬为 ...
- LeetCode 1062. 最长重复子串(二分查找)
文章目录 1. 题目 2. 解题 1. 题目 给定字符串 S,找出最长重复子串的长度.如果不存在重复子串就返回 0. 示例 1: 输入:"abcd" 输出:0 解释:没有重复子串. ...
- LeetCode 483. 最小好进制(二分查找)
文章目录 1. 题目 2. 解题 1. 题目 对于给定的整数 n, 如果 n 的 k(k>=2)进制数的所有数位全为1,则称 k(k>=2)是 n 的一个好进制. 以字符串的形式给出 n, ...
最新文章
- java jni demo_Android JNI:让你一眼知之的JNI DEMO
- Workflow 4.0 中三种方式实现workflow的触发调用
- kali桥接模式无法上网_听没听过用手机接路由器上网?
- (译)理解 LSTM 网络 (Understanding LSTM Networks by colah)
- mysql acid_Mysql中ACID的原理
- if...elif...else...fi和case...esac的脚本条件判断式
- python语句join_详解Python中的join()函数的用法
- 生产库中遇到mysql的子查询
- 加快FineReport报表设计的几个心得体会
- bs 网站获取电子秤重量方案
- python除法运算定律有哪些_运算定律有哪些
- myexcel导入导出数据
- 【LeetCode】275. H指数 II
- 加密和解密的应用_万金油_新浪博客
- css与背景相关的属性有哪些,css的背景background的相关属性
- 分析了网易云数十万歌单后写出2020年的最全歌单推荐
- 小米8se怎么解屏幕锁_小米8 SE解锁system系统分区教程_小米8SE如何一键解锁系统分区...
- 抖音CLICKID+淘宝Relaitionid回传淘积木APP内下单--转化归因联调ROI程序算法及代码技术实现
- Android调整Bitmap图片大小
- 计算机专业-找工作相关经验