【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;
    }
};

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

相关推荐
宝贝儿好7 小时前
【NLP】第八章:项目实操案例:文本情感分析
人工智能·python·深度学习·算法·自然语言处理
如竟没有火炬7 小时前
恢复二叉搜索树
数据结构·数据库·python·leetcode·动态规划
如竟没有火炬7 小时前
整数拆分——动态规划
开发语言·数据结构·python·算法·leetcode·动态规划
叫我:松哥7 小时前
基于数据挖掘的旅游景点个性化推荐系统设计与实现,Apriori和FP-Growth算法挖掘景点之间的关联规则
人工智能·python·算法·数据挖掘·数据分析·beautifulsoup
KaMeidebaby7 小时前
卡梅德生物技术快报|噬菌体筛选:技术实操:宽谱大肠杆菌噬菌体筛选全流程与性能验证方案
前端·人工智能·算法·数据挖掘·数据分析
Hillain7 小时前
软件设计师设计模式
java·开发语言·经验分享·笔记·算法·设计模式·软考
战族狼魂7 小时前
AI 量化交易完整学习路线(从零到实战)
人工智能·算法·chatgpt·大语言模型·ai提示词·ai工程化
Frostnova丶16 小时前
【算法笔记】数学知识
笔记·算法
吴可可12316 小时前
AutoCAD 2016与2014二次开发关键差异
算法
雨白17 小时前
哈希:以时间换空间的算法实战
算法