文章目录

  • 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. 完成旅途的最少时间(二分查找)相关推荐

  1. 力扣 6010. 完成旅途的最少时间

    题目 给你一个数组 time ,其中 time[i] 表示第 i 辆公交车完成 一趟旅途 所需要花费的时间. 每辆公交车可以 连续 完成多趟旅途,也就是说,一辆公交车当前旅途完成后,可以 立马开始 下 ...

  2. [二分法]leetcode2187:完成旅途的最少时间(medium)

    题目: 题解: 思路:二分法 关于如何想到使用二分时间t呢? 首先题目说的是给定一个时间 t,然后求每辆公交车可以在这个时间t内能完成的旅途数,用t/a[i]来表示第i辆公交车在时间t内能完成的旅途数 ...

  3. leetcode2187. 完成旅途的最少时间(mid)(282)

    完成旅途的最少时间 代码 力扣链接 代码 class Solution {public long minimumTime(int[] time, int totalTrips) {long l = 1 ...

  4. LeetCode 1231. 分享巧克力(极小极大化 二分查找)

    文章目录 1. 题目 2. 解题 1. 题目 你有一大块巧克力,它由一些甜度不完全相同的小块组成.我们用数组 sweetness 来表示每一小块的甜度. 你打算和 K 名朋友一起分享这块巧克力,所以你 ...

  5. LeetCode-完成旅途的最少时间

    题目 给你一个数组 time ,其中 time[i] 表示第 i 辆公交车完成 一趟旅途 所需要花费的时间. 每辆公交车可以 连续 完成多趟旅途,也就是说,一辆公交车当前旅途完成后,可以 立马开始 下 ...

  6. LeetCode:数组(排列组合,二分查找I,二分查找II)

    1,排列组合 38,剑指Offer:字符串的排列 题目:输入一个字符串,打印出该字符串中字符的所有排列.你可以以任意顺序返回这个字符串数组,但里面不能有重复元素. class Solution {Li ...

  7. LeetCode 1235. 规划兼职工作(动态规划+二分查找)

    文章目录 1. 题目 2. 解题 1. 题目 你打算利用空闲时间来做兼职工作赚些零花钱. 这里有 n 份兼职工作,每份工作预计从 startTime[i] 开始到 endTime[i] 结束,报酬为 ...

  8. LeetCode 1062. 最长重复子串(二分查找)

    文章目录 1. 题目 2. 解题 1. 题目 给定字符串 S,找出最长重复子串的长度.如果不存在重复子串就返回 0. 示例 1: 输入:"abcd" 输出:0 解释:没有重复子串. ...

  9. LeetCode 483. 最小好进制(二分查找)

    文章目录 1. 题目 2. 解题 1. 题目 对于给定的整数 n, 如果 n 的 k(k>=2)进制数的所有数位全为1,则称 k(k>=2)是 n 的一个好进制. 以字符串的形式给出 n, ...

最新文章

  1. java jni demo_Android JNI:让你一眼知之的JNI DEMO
  2. Workflow 4.0 中三种方式实现workflow的触发调用
  3. kali桥接模式无法上网_听没听过用手机接路由器上网?
  4. (译)理解 LSTM 网络 (Understanding LSTM Networks by colah)
  5. mysql acid_Mysql中ACID的原理
  6. if...elif...else...fi和case...esac的脚本条件判断式
  7. python语句join_详解Python中的join()函数的用法
  8. 生产库中遇到mysql的子查询
  9. 加快FineReport报表设计的几个心得体会
  10. bs 网站获取电子秤重量方案
  11. python除法运算定律有哪些_运算定律有哪些
  12. myexcel导入导出数据
  13. 【LeetCode】275. H指数 II
  14. 加密和解密的应用_万金油_新浪博客
  15. css与背景相关的属性有哪些,css的背景background的相关属性
  16. 分析了网易云数十万歌单后写出2020年的最全歌单推荐
  17. 小米8se怎么解屏幕锁_小米8 SE解锁system系统分区教程_小米8SE如何一键解锁系统分区...
  18. 抖音CLICKID+淘宝Relaitionid回传淘积木APP内下单--转化归因联调ROI程序算法及代码技术实现
  19. Android调整Bitmap图片大小
  20. 计算机专业-找工作相关经验

热门文章

  1. 转换文档参数_明明2秒可以搞定Word、Excel相互转换,你却用了半小时!真亏了...
  2. MySQL中(delete、truncate、drop) 的区别
  3. Day05-循环和列表字符串、元组和字典
  4. 非法操作 login.php,阅文游戏中心 h5游戏接入wiki
  5. 数据结构:神奇的B树实现解析(有图有代码有真相!!!)
  6. 结构体定义的三钟方式
  7. python day15
  8. (二)AS给button添加点击事件
  9. 康纳的表情包(思维)
  10. 接口测试工具-fiddler的运用