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;
    }
};
相关推荐
hans汉斯2 分钟前
国产生成式人工智能解决物理问题能力研究——以“智谱AI”、“讯飞星火认知大模型”、“天工”、“360智脑”、“文心一言”为例
大数据·人工智能·算法·aigc·文心一言·汉斯出版社·天工
v_for_van5 分钟前
力扣刷题记录3(无算法背景,纯C语言)
c语言·算法·leetcode
ValhallaCoder9 分钟前
hot100-矩阵
数据结构·python·算法·矩阵
散峰而望10 分钟前
【基础算法】穷举的艺术:在可能性森林中寻找答案
开发语言·数据结构·c++·算法·随机森林·github·动态规划
心.c12 分钟前
Vue3+Node.js实现文件上传分片上传和断点续传【详细教程】
前端·javascript·vue.js·算法·node.js·哈希算法
散峰而望12 分钟前
【基础算法】算法的“预谋”:前缀和如何改变游戏规则
开发语言·数据结构·c++·算法·github·动态规划·推荐算法
We་ct13 分钟前
LeetCode 48. 旋转图像:原地旋转最优解法
前端·算法·leetcode·typescript
爱尔兰极光13 分钟前
LeetCode--长度最小的子数组
算法·leetcode·职场和发展
仰泳的熊猫14 分钟前
题目1432:蓝桥杯2013年第四届真题-剪格子
数据结构·c++·算法·蓝桥杯·深度优先·图论
有一个好名字21 分钟前
力扣-电话号码组合
算法·leetcode·职场和发展