leetcode 2141

2141: 同时运行N台电脑的最长时间

k 是可以通过二分查找确定的。如果可以运行 k 分钟,那么也一定可以运行 k−1,k−2,⋯ 分钟。因此一定存在一个 k′,使得我们可以运行 ≤k′分钟,但不能运行 >k′分钟,此时 k′就是我们需要求出的答案。

思路:运行时间k是有范围限制的,因此可以考虑二分查找。

1.假设可以让 n 台电脑同时运行 x 分钟,那么对于电量大于 x 的电池,其只能被使用 x 分钟,因此每个电池的使用时间至多为 min(batteries[i],x)。累加所有电池的使用时间,记作 sum。那么要让 n 台电脑同时运行 x 分钟,必要条件是 n⋅x≤sum。

2.当 总的可供电时间>=mid*n,代表当前mid可行

  • 开区间左端点初始值:0,不运行任何电脑,一定满足要求。
  • 开区间右端点初始值:平均值加一,即 ⌊∑batteries[i] / n⌋+1。一定无法满足要求。

下面代码采用开区间二分:

复制代码
class Solution {
public:
    long long maxRunTime(int n, vector<int>& batteries) {
        long long tot=reduce(batteries.begin(),batteries.end(),0LL);
        long long l=0,r=tot/n+1;
        while(l+1<r){
            long long mid=l+(r-l)/2;
            long long sum=0;
            for(long long b :batteries){
                sum+=min(b,mid);   //表示可以让 n 台电脑同时运行mid分钟
            }
            if(n*mid <= sum)l=mid;
            else r=mid;
        }

        return l;
    }
};
相关推荐
云青黛20 小时前
ReAct(推理与行动)框架
python·算法
易雪寒20 小时前
Java List 根据List中对象的属性值是否相同作为同一组,分割成多个连续的子List
java·数据结构·list·分组切割
im_AMBER20 小时前
Leetcode 142 将有序数组转换为二叉搜索树 | 排序链表
算法·leetcode
码农三叔20 小时前
(10-5-01)大模型时代的人形机器人感知:基于RoboBrain大模型的人形机器人通用智能感知系统(1)构建模型
人工智能·算法·机器人·人形机器人
scott19851220 小时前
扩散模型之(十三)条件生成 Conditioned Generation
人工智能·算法·生成式
Wect20 小时前
LeetCode 53. 最大子数组和:两种高效解法(动态规划+分治)
前端·算法·typescript
春日见20 小时前
端到端自动驾驶综述
linux·人工智能·算法·机器学习·自动驾驶
Book思议-21 小时前
【数据结构实战】单向循环单链表判别条件理解
c语言·数据结构·算法
逆境不可逃21 小时前
【后端新手谈 04】Spring 依赖注入所有方式 + 构造器注入成官方推荐的原因
java·开发语言·spring boot·后端·算法·spring·注入方式
Book思议-21 小时前
【数据结构实战】双向链表头插法
c语言·数据结构·链表