每日一题:leetcode 2594 修车的最少时间

news/2024/6/17 21:40:55 标签: leetcode, 算法

给你一个整数数组 ranks ,表示一些机械工的 能力值 。ranksi 是第 i 位机械工的能力值。能力值为 r 的机械工可以在 r * n2 分钟内修好 n 辆车。

同时给你一个整数 cars ,表示总共需要修理的汽车数目。

请你返回修理所有汽车 最少 需要多少时间。

注意:所有机械工可以同时修理汽车。

示例 1:

输入:ranks = [4,2,3,1], cars = 10
输出:16
解释:
- 第一位机械工修 2 辆车,需要 4 * 2 * 2 = 16 分钟。
- 第二位机械工修 2 辆车,需要 2 * 2 * 2 = 8 分钟。
- 第三位机械工修 2 辆车,需要 3 * 2 * 2 = 12 分钟。
- 第四位机械工修 4 辆车,需要 1 * 4 * 4 = 16 分钟。
16 分钟是修理完所有车需要的最少时间。

示例 2:

输入:ranks = [5,1,8], cars = 6
输出:16
解释:
- 第一位机械工修 1 辆车,需要 5 * 1 * 1 = 5 分钟。
- 第二位机械工修 4 辆车,需要 1 * 4 * 4 = 16 分钟。
- 第三位机械工修 1 辆车,需要 8 * 1 * 1 = 8 分钟。
16 分钟时修理完所有车需要的最少时间。

提示:

  • 1 <= ranks.length <= 105
  • 1 <= ranks[i] <= 100
  • 1 <= cars <= 106

Related Topics

  • 数组
  • 二分查找

思路:

一开始我想是贪心算法,将数组按照rank能力进行升序排序,然后通过优先队列去模拟选人的过程,后来发现思路不对。因为没办法判断每个人应该会修理多少辆车,模拟的话数据量过大应该会超时。

后来想,其实每个人的能力rank是固定的,那么不确定就是能修多少车。如果在确定的时间内,每个人能修理的车的数量其实是可以确定的。根据题目给的公式 rank[i] * n * n = time,那么 n = 根号(time / rank[i])。这样就明确了,我只需要在一个范围里面进行判断最小的time是什么就行了,这个范围就是[1 - x * n * n],其中x是随便某个人的rank,n是全部汽车数,即就是随便一个人修完全部车的时间。

最终,这个算法其实就是二分答案,初听这个名字有点炫酷,但是其实就是二分查找,在答案范围内进行查询,找到满足条件的最值即可。(一般二分答案都是解决在某个条件内,最大最小的极值问题)

ac code:

class Solution {
    public long repairCars(int[] ranks, int cars) {
        long ans = 1l * ranks[0] * cars * cars;
        long left = 1;
        long right = ans;
        while (left < right) {
            long mid = left + (right - left) / 2; // 防止数据溢出的小技巧
            if (check(ranks, cars, mid)) { // 二分查询
                ans = mid;
                right = mid;
            } else {
                left = mid + 1;
            }
        }
        return ans;
    }


    // 判断答案是否满足
    private boolean check(int[] ranks, int cars, long mid) {
        long cnt = 0;
        for (int x : ranks) {
            cnt += (long) Math.sqrt(mid / x);
        }
        return cnt >= cars;
    }
}


http://www.niftyadmin.cn/n/5016747.html

相关文章

rman异机恢复的异常处理

因客户需要测试&#xff0c;使用生产环境的rman备份在虚拟机恢复中&#xff0c;忘记调整redo位置&#xff0c;打开时报错及处理过程。 SQL> alter database open resetlogs; alter database open resetlogs * ERROR at line 1: ORA-00344: unable to re-create online …

SAP 创建动态内表

创建动态内表 一、根据表名创建内表 程序代码&#xff1a; "复杂方式 SELECTION-SCREEN BEGIN OF BLOCK b1 WITH FRAME TITLE TEXT-001. PARAMETERS:p_tab TYPE string. SELECTION-SCREEN END OF BLOCK b1.DATA:lr_struct TYPE REF TO data,lr_table TYPE REF TO data. …

python爬虫的反扒技术有哪些如何应对

Python爬虫常见的反扒技术主要有以下几种: IP封禁&#xff1a;有些网站会限制爬虫的IP访问频率&#xff0c;如果访问流量过大&#xff0c;可能会被封禁IP。可以通过使用代理IP或者轮换IP的方式规避此类反扒技术。 用户代理限制&#xff1a;有些网站会通过检测请求头中的用户代…

AtCoder Beginner Contest 319

AtCoder Beginner Contest 319 A - Legendary Players 思路&#xff1a; 直接map存以下输出即可 #include<bits/stdc.h> using namespace std; #define int long long #define rep(i,a,n) for(int ia;i<n;i) #define per(i,a,n) for(int in;i>a;i--) #define pb…

torch.cuda.is_available() 解决方

本人使用的显卡如下&#xff0c;打开任务管理器查看 Anaconda下载哪个版本都可以 使用命令conda create -n pytorch python3.6创建一个名为pytorch的环境&#xff0c;解释器使用3.6的 使用命令conda activate pytorch进入该环境 进入pytorch官网&#xff0c;选择下列选项 复…

LabVIEW通过IEC61508标准验证ITER联锁系统

LabVIEW通过IEC61508标准验证ITER联锁系统 保护环境要求系统能够保护机器免受工厂系统故障或机器危险操作造成的严重损坏。负责此功能的ITER系统是联锁控制系统&#xff08;ICS&#xff09;。该系统通过中央联锁系统&#xff08;CIS&#xff09;监督和控制不同的工厂联锁系统&…

Java中如何获取一个字符串是什么类型

Java中如何获取一个字符串是什么类型&#xff1f; 在Java中&#xff0c;您可以使用一些方法来确定一个字符串的类型。下面是一些常用的方法&#xff1a; 使用正则表达式&#xff1a;您可以使用正则表达式来匹配字符串是否符合特定的模式或格式&#xff0c;以确定其类型。例如&…

时间管理类书籍阅读笔记

背景 这段时间看了时间管理方面的书籍&#xff0c;大部分和早晨时间利用相关。之所以有了利用早晨时间的想法&#xff0c;是某天下班后&#xff0c;感觉很疲惫&#xff0c;什么都不想做&#xff0c;于是就打了一晚上游戏&#xff0c;然后第二天重复着这样的生活。 突然意识到…