当前位置: 首页 > news >正文

力扣每日一题---2594. 修车的最少时间

在这里插入图片描述

文章目录

  • 思路
  • 解题方法
  • 复杂度
  • Code

思路

请注意,能力值越低,修车越快,应该翻译成「排名」,排名越靠前,修车越快。)根据题意可以知道r * n * n <= t 的,所以可以利用数学知识进行改变公式,n <= sqrt(t / r),所以能力值为 r 的工人最多可以修 sqrt(t / r) 辆车 然后累计起来就是总和,所以 t 越大表示能修理的车车越多,所以有了这样的单调性,我们就可以二分答案了。

解题方法

背y总的二分模板

复杂度

  • 时间复杂度:

添加时间复杂度, 示例: O ( l o g n ) O(logn) O(logn)

Code

class Solution 
{bool check(vector<int>& ranks, int cars,long long mid){    long long s = 0;for(auto& r : ranks)//遍历数组然后求出所有工人可以修理的车车的总数s += sqrt(mid / r);return s >= cars;//满足需要修理的车车数量就返回true 否则 false}public:long long repairCars(vector<int>& ranks, int cars) {    //下面全是y总的二分模板long long left = 0, right = 1e14, mid;while(left<right){mid = (left + right) / 2;if(check(ranks,cars,mid)) right = mid;else left = mid+1;}return right;}
};

在这里插入图片描述

http://www.lryc.cn/news/157471.html

相关文章:

  • 【jvm】运行时数据区
  • SpringMVC相对路径和绝对路径
  • IIS perl python cbrother php脚本语言配置及简单测试样例程序
  • Oracle Scheduler中日期表达式和PLSQL表达式的区别
  • Java设计模式:一、六大设计原则-06:依赖倒置原则
  • 信息系统数据同步解决方案
  • LRU算法 vs Redis近似LRU算法
  • 浅析ARMv8体系结构:异常处理机制
  • Golang开发--Goroutine的使用
  • 【Linux】package ‘python-yaml‘ has no installation candidate 如何解决
  • Selector选择器在AspNetCore中的用法
  • anaconda3最新版安装|使用详情|Error: Please select a valid Python interpreter
  • java八股文面试[多线程]——锁的分类
  • 儿童安全门和围栏,以及游戏围栏等美国站要求的合规标准是什么?
  • kafka配合ElasticStack技术栈的搭配使用
  • 对极几何与三角化求3D空间坐标
  • 英语语法笔记
  • ES6的面向对象编程以及ES6中的类和对象
  • ConfigMaps in K8s
  • 《机器人学一(Robotics(1))》_台大林沛群 第 6 周 【轨迹规划_直线转折处抛物线平滑】Quiz 6
  • 关于vscode的GitLens插件里的FILE HISTORY理解
  • 通过idea实现springboot集成mybatys
  • 力扣(LeetCode)算法_C++——移位字符串分组
  • Vue2 与Vue3的区别?面试题
  • java代码:Random和Scanner应用的小例子-猜数字小游戏
  • python调用git出错:ImportError: Failed to initialize: Bad git executable.
  • 【C语言】入门——指针
  • C#_预处理指令
  • 容器命令(docker)
  • Vue3 ElementPlus el-cascader级联选择器动态加载数据