LeetCode 1870. 准时到达的列车最小时速(二分查找)

文章目录

    • 1. 题目
    • 2. 解题
      • 2.1 模拟超时
      • 2.2 二分查找

1. 题目

给你一个浮点数 hour ,表示你到达办公室可用的总通勤时间。
要到达办公室,你必须按给定次序乘坐 n 趟列车。
另给你一个长度为 n 的整数数组 dist ,其中 dist[i] 表示第 i 趟列车的行驶距离(单位是千米)。

每趟列车均只能在整点发车,所以你可能需要在两趟列车之间等待一段时间。

例如,第 1 趟列车需要 1.5 小时,那你必须再等待 0.5 小时,搭乘在第 2 小时发车的第 2 趟列车。
返回能满足你准时到达办公室所要求全部列车最小正整数 时速(单位:千米每小时),如果无法准时到达,则返回 -1 。

生成的测试用例保证答案不超过 10^7 ,且 hour 的 小数点后最多存在两位数字 。

示例 1:
输入:dist = [1,3,2], hour = 6
输出:1
解释:速度为 1 时:
-1 趟列车运行需要 1/1 = 1 小时。
- 由于是在整数时间到达,可以立即换乘在第 1 小时发车的列车。第 2 趟列车运行需要 3/1 = 3 小时。
- 由于是在整数时间到达,可以立即换乘在第 4 小时发车的列车。第 3 趟列车运行需要 2/1 = 2 小时。
- 你将会恰好在第 6 小时到达。示例 2:
输入:dist = [1,3,2], hour = 2.7
输出:3
解释:速度为 3 时:
-1 趟列车运行需要 1/3 = 0.33333 小时。
- 由于不是在整数时间到达,故需要等待至第 1 小时才能搭乘列车。第 2 趟列车运行需要 3/3 = 1 小时。
- 由于是在整数时间到达,可以立即换乘在第 2 小时发车的列车。第 3 趟列车运行需要 2/3 = 0.66667 小时。
- 你将会在第 2.66667 小时到达。示例 3:
输入:dist = [1,3,2], hour = 1.9
输出:-1
解释:不可能准时到达,因为第 3 趟列车最早是在第 2 小时发车。提示:
n == dist.length
1 <= n <= 10^5
1 <= dist[i] <= 10^5
1 <= hour <= 10^9
hours 中,小数点后最多存在两位数字

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/minimum-speed-to-arrive-on-time
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

类似题目:LeetCode 1231. 分享巧克力(极小极大化 二分查找)

2.1 模拟超时

51 / 53 个通过测试用例

class Solution {
public:int minSpeedOnTime(vector<int>& dist, double hour) {int n = dist.size();if(n > ceil(hour))return -1;long s = 0;for(int i = 0; i < n; ++i)s += dist[i];int v = s/hour-1;if(v <= 0) v = 1;while(1){double t = 0;for(int i = 0; i < n-1; ++i){   t += ceil(dist[i]/double(v));}t += dist.back()/double(v);if(t <= hour)break;v++;}return v;}
};

2.2 二分查找

v 的增加,总得到达时间不会变多,具有单调性,采用二分查找

class Solution {
public:int minSpeedOnTime(vector<int>& dist, double hour) {int n = dist.size();if(n > ceil(hour))return -1;int l = 1, r = 1e9, ans, v;while(l <= r){v = (l+r)>>1;double t = 0;for(int i = 0; i < n-1; ++i)t += ceil(dist[i]/double(v));t += dist.back()/double(v);if(t <= hour){ans = v;r = v-1;}elsel = v+1;}return ans;}
};

308 ms 98.8 MB C++


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/472194.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

jdk1.5新特性

“JDK1.5”&#xff08;开发代号猛虎&#xff09;的一个重要主题就是通过新增一些特性来简化开发&#xff0c;这些特性包括泛型&#xff0c;for-else 循环&#xff0c;自动装包/拆包&#xff0c;枚举&#xff0c;可变参数, 静态导入 。使用这些特性有助于我们编写更加清晰&…

jsonp跨域原理_Rust 搭建可跨域访问服务器JsonP(一)

最近有一个项目极有可能需要一个可跨域的服务器做一个中转&#xff0c;思来想去决定用Rust来实现这个服务器&#xff0c;因为有如下优点。1、编译体积小 2、跨平台 3、安全性较高JsonP(JSON with Padding)&#xff1a;带有填充的JSON&#xff0c;这里的填充指的是回调函数。为什…

【Python基础知识-pycharm版】第十一节-文件操作(IO技术)

第十一节-文件操作&#xff08;IO技术&#xff09;文本文件和二进制文件文件操作相关模块概述创建文件对象 open()文本文件的写入基本的文件写入操作常用编码介绍ASCIIISO8859-1GB2312,GBK,GB18030中文乱码问题write()/writelines()写入数据close()关闭文件流with 语句(上下文管…

LeetCode 1871. 跳跃游戏 VII(贪心)

文章目录1. 题目2. 解题1. 题目 给你一个下标从 0 开始的二进制字符串 s 和两个整数 minJump 和 maxJump 。 一开始&#xff0c;你在下标 0 处&#xff0c;且该位置的值一定为 0 。 当同时满足如下条件时&#xff0c;你可以从下标 i 移动到下标 j 处&#xff1a; i minJump …

pcb外观维修_「维修案例」泰克AFG3021函数任意波形发生器故障维修

在产品调试的过程中&#xff0c;大多数的电路需要输入某种幅度随时间变化的信号&#xff0c;在这样的应用场景中&#xff0c;一个完整的测试测量系统一般会包含激励源&#xff0c;被测件和采集仪器三个部分。采集仪器通常使用的是示波器和逻辑分析仪&#xff0c;而信号源在系统…

sass 安装和使用

1&#xff0c;安装ruby :检查本地是否安装ruby&#xff1a; #ruby -v 2&#xff0c;安装sass&#xff1a; #gem install sass 3&#xff0c;检查是否安装成功&#xff1a;#sass -v 4&#xff0c;.scss文件不能直接被浏览器解析&#xff0c;需要转化成css文件&#xff0c;您不必…

设计模式--迭代器模式

实验18&#xff1a;迭代器模式 本次实验属于模仿型实验&#xff0c;通过本次实验学生将掌握以下内容&#xff1a; 1、理解迭代器模式的动机&#xff0c;掌握该模式的结构&#xff1b; 2、能够利用迭代器模式解决实际问题。 [实验任务]&#xff1a;JAVA和C常见数据结构迭代…

4k视频分辨率的码流_8K电视来了!但是8K视频仍很遥远

本届CES上&#xff0c;8K电视的集体发布可谓一大亮点&#xff0c;索尼、LG、TCL、三星等厂商纷纷推出8K电视。不光如此&#xff0c;本届CES上夏普突如其来的展示了一款具备8K视频拍摄功能的M43相机&#xff0c;这一点着实是出乎意料。今天我们就来讨论一下&#xff0c;在8K电视…

LeetCode 1707. 与数组中元素的最大异或值(Trie树)

文章目录1. 题目2. 解题1. 题目 给你一个由非负整数组成的数组 nums 。另有一个查询数组 queries &#xff0c;其中 queries[i] [xi, mi] 。 第 i 个查询的答案是 xi 和任何 nums 数组中不超过 mi 的元素按位异或&#xff08;XOR&#xff09;得到的最大值。 换句话说&#x…

wu

&#xff40;&#xff40;&#xff40;&#xff40;&#xff40;看我的csdn博客吧http://blog.csdn.net/wwx_from_tju转载于:https://www.cnblogs.com/wwxtju/p/4374918.html

学报格式和论文格式一样吗_学报参考文献标准格式

学报参考文献标准格式毕业论文参考文献规范格式是怎么样的&#xff1f;怎么样才是标准的&#xff0c;看看下面的学报参考文献标准格式吧&#xff01;学报参考文献标准格式一、参考文献的类型参考文献(即引文出处)的.类型以单字母方式标识&#xff0c;具体如下&#xff1a;M——…

我的爬虫第一天

爬虫一个简单的爬虫&#xff1a;1.安装request2.测试是否安装成功3.新建项目4.使用requests请求网页4.如何用python解析网页源码5.简单的保存数据的方法一个简单的爬虫&#xff1a; 1.安装request pip install requests2.测试是否安装成功 输入python import requests不报…

qr分解求线性方程组_计算方法/数值分析第三章 线性方程组的数值解法

主要内容&#xff1a;1、引言2、高斯消去法3、直接分解法4、解线性方程组的迭代法5、向量范数、矩阵范数及迭代法的收敛性第一节 引言用克拉姆求解线性方程组第二节 高斯消去法高斯消去法是一种古老的直接法&#xff0c;其基本思想是通过消元将线性方程组的求解问题转化成三角形…

判断成绩及格优良

依旧是if语句的简单练习 if嵌套&#xff0c;满足前提条件才能执行条件下的语句 namespace ConsoleApplication9 {class Program{static void Main(string[] args){while (true){Console.Write("请输入姓名&#xff1a;");Console.ReadLine();Console.Write("请输…

python 执行完成后,cmd窗口自动关闭

一般脚本运行完需要点击一下 在代码最后添加以下内容即可自动关闭cmd&#xff1a; import os import time time.sleep(1) # 方便展示&#xff0c;可删除 os.system("taskkill /f /im cmd.exe") # 关闭cmd窗口

txt文件可存储最大值_Verilog边码边学:十六进制文件读取$readmemh

系统任务$readmemh读取十六进制文件。$readmemh的作用是将文件中的数据一次性的读入某个数组中&#xff0c;然后可以依次从数组中取出单个的数据进行处理。读取的内容只包括空白位置(空格、换行、制表格)、注释行、十六进制的数字。语法结构中的起始地址与终止地址可省略。【语…

什么叫诚实_他爱不爱你,身体最诚实

文字&#xff1a;嘉一 声音&#xff1a;三三有位听友给我发私信说&#xff1a;“他看我的眼神变了&#xff0c;也不喜欢和我说话了&#xff0c;更懒得为我做任何事了&#xff0c;这段感情真的没意思了。”我回她&#xff1a;“一个人爱不爱你&#xff0c;身体最诚实。嘴巴可以…

【机器学习-数据科学】第一节:numpypandas

numpy&pandas安装numpy&pandasarray创建numpy的基础运算numpy的索引numpy的 array 合并numpy的 array分割numpy的 copy & deep copy安装numpy&pandas import numpy as np arraynp.array([[1,2,3],[2,3,4]])# 将数组转化为矩阵 print(array) #打印矩阵 print(nu…

python 剪切一行内容到另一个文件

自己做机器学习项目&#xff0c;手动打标签&#xff0c;完成后剪切一行数据到文件 参考内容&#xff1a;https://www.cnblogs.com/Dreamer-qiao/p/7390469.html # 剪切一行数据到另外一个文件 # 用途&#xff1a;自己做机器学习数据&#xff0c;打标签&#xff0c;标记source…

[整理]详记被忽略的Get与Post

[事发]使用了近5年的项目&#xff0c;来了一个最最基本的bug画面输入号&#xff0c;跳转至后画面&#xff0c;号变成了空格&#xff01;[原因]画面使用url(get)方法传参数&#xff0c;并且没有进行url转码&#xff01;恐怖的是&#xff0c;几乎所有页面都是如此...[解决办法]1.…