【LeetCode刷题】410. 分割数组的最大值

  • [1. 题目链接](#1. 题目链接)
  • [2. 题目描述](#2. 题目描述)
  • [3. 解题方法](#3. 解题方法)
  • [4. 代码](#4. 代码)

1. 题目链接

410. 分割数组的最大值

2. 题目描述

3. 解题方法

题目中提到的是某个和的最大值是最小的,这种题目是可以用二分来解决的。

  1. 确定区间,根据题目的数据范围,可以确定区间就是[0, 1e9]。
  2. 每次找到的数,都要去check一下,看是否满足要求。
  3. 满足的条件就是,是否有子数组刚好等于这个数并且子数组的个数还必须小于题目给的k。

4. 代码

cpp 复制代码
class Solution {
public:
    int splitArray(vector<int>& nums, int k) 
    {
        int l = 0, r = (int)1e9;
        while(l < r)
        {
            int mid = (r - l) / 2 + l;
            if(check(mid, nums, k)) r = mid;
            else l = mid + 1;
        }
        return r;
    }
    bool check(int mid, vector<int>& nums, int k)
    {
        int cnt = 1, sum = 0;
        for(auto e : nums)
        {
            if(sum + e <= mid) sum += e;
            else 
            {
                if(e > mid) return false;
                cnt ++;
                sum = e;
            }
        }
        return cnt <= k;
    }
};

最后附上我的打卡记录,希望各位大佬可以监督我一下。

相关推荐
柒月的猫11 分钟前
求和(2022蓝桥杯A组试题C)
c语言·算法·蓝桥杯
simple_ssn18 分钟前
【蓝桥杯】压缩字符串
java·算法
-$_$-36 分钟前
【LeetCode 面试经典150题】详细题解之哈希表篇
leetcode·面试·散列表
c1assy1 小时前
DP动态规划+贪心题目汇总
数据结构·算法·leetcode·贪心算法·动态规划
jjjxxxhhh1231 小时前
C++ 模板是为了解决啥问题
开发语言·c++·算法
c++初学者ABC1 小时前
GESP2级2403 小杨的日字矩阵
c++·算法
大写-凌祁2 小时前
2024国赛A题第一问
线性代数·算法·机器学习·数学建模
代码小将2 小时前
PTA数据结构编程题7-1最大子列和问题
数据结构·c++·笔记·学习·算法
pk_xz1234562 小时前
R 和 Origin 完成细菌 OTU 表、土壤理化性质数据的微生物 Beta 多样性分析
算法·机器学习·r语言
Ning_.2 小时前
力扣第116题:填充每个节点的下一个右侧节点指针 - C语言解法
c语言·算法·leetcode