小张刷题计划(二)

解决方案

给定一个数组,将其划分成M份,使得每份元素之和最大值最小,每份可以任意减去其中一个元素。

题解

如果不考虑每份可以任意减去一个元素,就是一个经典的二分问题。具有单调最优的性质:如果最大值为t可以满足条件划分,那么最大值为t+1也可以。所以就直接二分最大值 ,找到最小满足条件的t即可。

本题加了一个条件:每份可以删除任意一个数组。为了能够让最大值最小,显然每份中删去的一定是最大元素,所以在二分判定可行性时,维护当前序列的最大值,然后记录删除最大值的结果,也就是说二分的判定是:是否可以让每组删除最大值之后,总和都小于等于t。

C++ 实现

复制代码
class Solution {
public:
    bool Check(int limit, vector<int> cost, int day) {
      // 每组划分 limit 的最大和,贪心划分看有多少组
        int useday, totaltime, maxtime;
        useday = 1; totaltime = maxtime = 0;
        for (int i=0; i<cost.size(); ++i) {
            int nexttime = min(maxtime, cost[i]);
            if (nexttime + totaltime <= limit) {
                totaltime += nexttime;
                maxtime = max(maxtime, cost[i]);
            } else {
                ++useday;
                totaltime = 0;
                maxtime = cost[i];
            }
        }
        return (useday <= day);
    }
    int minTime(vector<int>& time, int m) {
        int left, right, middle;
        left = right = 0;
        for (int i=0; i<time.size(); ++i) {
            right += time[i];
        }
        while (left <= right) {
            middle = (left + right) >> 1;
            if (Check(middle, time, m)) right = middle - 1;
            else left = middle + 1;
        }
        return left;
    }
};

复杂度分析

相关推荐
苦藤新鸡4 分钟前
21.在有序的二位数组中用O(m+n)的算法找target
算法
小尧嵌入式6 分钟前
【Linux开发二】数字反转|除数累加|差分数组|vector插入和访问|小数四舍五入及向上取整|矩阵逆置|基础文件IO|深入文件IO
linux·服务器·开发语言·c++·线性代数·算法·矩阵
one____dream8 分钟前
【算法】大整数数组连续进位
python·算法
one____dream9 分钟前
【算法】合并两个有序链表
数据结构·python·算法·链表
大江东去浪淘尽千古风流人物9 分钟前
【Project Aria】Meta新一代的AR眼镜及其数据集
人工智能·嵌入式硬件·算法·性能优化·ar·dsp开发
电饭叔9 分钟前
has_solution = False 是什么 费马大定律代码化和定理《计算机科学中的数学》外扩学习3
学习·算法
We་ct10 分钟前
LeetCode 238. 除了自身以外数组的乘积|最优解详解(O(n)时间+O(1)空间)
前端·算法·leetcode·typescript
闻缺陷则喜何志丹11 分钟前
【动态规划】P9980 [USACO23DEC] Flight Routes G|普及+
c++·算法·动态规划·洛谷
Σίσυφος190011 分钟前
视觉矩阵之 正交矩阵
人工智能·算法·矩阵
wen__xvn12 分钟前
基础算法集训第21天:Bellman-Ford
算法