• 入门力扣自学笔记280 C++ (题目编号:1123)(二分查找)(多看看)


    2594. 修车的最少时间

    题目:

    给你一个整数数组 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 <= 10^{5}
    • 1 <= ranks[i] <= 100
    • 1 <= cars <= 10^{6}

    代码:

    1. class Solution {
    2. public:
    3. long long repairCars(vector<int>& ranks, int cars) {
    4. long long upper_bound = (long long)ranks[0] * cars * cars, lower_bound = 0;
    5. return binary_search(0, upper_bound, cars, ranks);
    6. }
    7. bool pass(vector<int>& ranks, int cars, long long& bound)
    8. {
    9. for(auto it = ranks.begin(); it != ranks.end(); it++)
    10. {
    11. int fixable = sqrt(bound / *it);
    12. cars -= fixable;
    13. if(cars <= 0)
    14. return true;
    15. }
    16. return false;
    17. }
    18. long long binary_search(long long begin, long long end, int cars, vector<int>& ranks)
    19. {
    20. long long mid;
    21. while(begin < end)
    22. {
    23. mid = (begin + end) / 2;
    24. if(pass(ranks, cars, mid))
    25. end = mid;
    26. else
    27. begin = mid + 1;
    28. }
    29. if(begin == mid + 1)
    30. return begin;
    31. else
    32. return end;
    33. }
    34. };

     

  • 相关阅读:
    市场需求预测模型
    如何为 Kubernetes 监控安装 Pixie
    mysql 5.7 解压版安装教程(之前是安装包,从其他电脑复制过来也适用)
    Java设计模式之解释器模式
    仓库管理流程详解(附作业流程图)
    CTF-SMB信息泄露【简单易懂】
    Apollo自动驾驶平台:从传感器到决策的技术解析
    @Zabbix6.2安装部署【 Red Hat Enterprise Linux 8.2】
    计算机网络_04_传输层
    【数据仓库设计基础(三)】数据集市
  • 原文地址:https://blog.csdn.net/DK_Sorhic/article/details/132742812