LeetCode 410. 分割数组的最大值

一、题目

1、题目描述

给定一个非负整数数组 nums 和一个整数 k ,你需要将这个数组分成 k个非空的连续子数组。

设计一个算法使得这 k个子数组各自和的最大值最小。

2、接口描述

复制代码
cpp 复制代码
class Solution {
public:
    int splitArray(vector<int>& nums, int k) {
        
    }
};

3、原题链接

410. Split Array Largest Sum


二、解题报告

1、思路分析

看到"最大的最小"自然想到二分

那么关键就在于给定x,如何判断原数组是否能够划分为最大值不超过x的k个子数组

我们贪心地思考,如果原数组能够划分为最大值不超过x的j个子数组,j < k,那么一定也可以通过拆解某些子数组从而得到k个子数组

所以我们的check函数,遍历数组,贪心累加,如果sum > x,我们就cnt + 1,然后sum = x

最终取决于cnt <= k

很经典的二分+贪心的题目

2、复杂度

时间复杂度:O(n) 空间复杂度:O(1)

3、代码详解

复制代码
cpp 复制代码
class Solution {
public:
    int splitArray(vector<int>& nums, int k) {
       int r = 0 , l = 0;
       for(auto x : nums) r += x , l = max(l , x);
       function<bool(int)> check = [&](int t)
       {
           int cnt = 1 , s = 0;
           for(auto x : nums){
                if(s + x > t)
                    s = x , cnt++;
                else
                    s += x;
           }
            return cnt <= k;
       };
       while(l < r)
       {
           int mid = (l + r) >> 1;
           if(check(mid)) r = mid;
            else l = mid + 1;
       }
       return r;
    }
};
相关推荐
那个村的李富贵11 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
power 雀儿12 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
Yvonne爱编码12 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
熬夜有啥好12 小时前
数据结构——哈希表
数据结构·散列表
琹箐12 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia113 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了13 小时前
数据结构之树(Java实现)
java·算法
算法备案代理13 小时前
大模型备案与算法备案,企业该如何选择?
人工智能·算法·大模型·算法备案
赛姐在努力.13 小时前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
我能坚持多久13 小时前
【初阶数据结构01】——顺序表专题
数据结构