LeetCode刷题日记(2594. 修车的最少时间)

'''
给你一个整数数组 ranks ,表示一些机械工的能力值 。
ranks i 是第 i 位机械工的能力值。能力值为 r 的机械工可以在 r * n^2 分钟内修好 n 辆车。
同时给你一个整数 cars ,表示总共需要修理的汽车数目。
请你返回修理所有汽车 最少 需要多少时间。
注意:所有机械工可以同时修理汽车。
'''
from typing import List


class Solution:
    def repairCars(self, ranks: List[int], cars: int) -> int:
        # 确定时间范围的上下界
        low = 1
        high = max(ranks) * cars * cars

        while low < high:
            mid = (low + high) // 2
            total_cars_fixed = 0

            # 计算在mid时间内每位机械工能修好多少辆车 利用二分搜索找到满足条件的最小值
            for rank in ranks:
                total_cars_fixed += int((mid // rank)**0.5)
            if total_cars_fixed >= cars:
                high = mid
            else:
                low = mid + 1
        return low

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值