[LeetCode] 53. 最大子数组和

题目描述:

给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

子数组

是数组中的一个连续部分。

示例 1:

复制代码
输入:nums = [-2,1,-3,4,-1,2,1,-5,4]
输出:6
解释:连续子数组 [4,-1,2,1] 的和最大,为 6 。

示例 2:

复制代码
输入:nums = [1]
输出:1

示例 3:

复制代码
输入:nums = [5,4,-1,7,8]
输出:23

提示:

  • 1 <= nums.length <= 105
  • -104 <= nums[i] <= 104

题目链接:
. - 力扣(LeetCode)

解题主要思想:

有了解过前缀和的话其实这道题很容易解决,我们只需要找到当前区间最大的前缀和和最小的前缀和(<=0)即可。

解题代码:

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int ret = INT_MIN;
        int min_pre_sum = 0;
        int pre_sum = 0;
        for (auto& x : nums) {
            pre_sum += x;
            ret = max(ret, pre_sum - min_pre_sum);
            min_pre_sum = min(pre_sum, min_pre_sum);
        }
        return ret; 
    }
};
相关推荐
sheeta19981 分钟前
LeetCode 每日一题笔记 日期:2026.05.21 题目:3043. 最长公共前缀的长度
笔记·算法·leetcode
加油20192 分钟前
嵌入式软件技术栈和学习路线详解
linux·arm开发·数据结构·mqtt·设计模式·嵌入式
Oj92q85H52 分钟前
如何在Dev-C++中使用TDM-GCC编译项目
linux·开发语言·c++
吃好睡好便好4 分钟前
创建随机矩阵
开发语言·人工智能·线性代数·算法·matlab·矩阵
小poop5 分钟前
STL 入门 + 三道高频面试题
c++
j_xxx404_7 分钟前
Linux线程控制:从用户态控制到内核级克隆全链路解析
linux·运维·服务器·开发语言·c++·ai
喵星人工作室11 分钟前
C++火影忍者1.1版本
开发语言·c++·游戏
插件开发16 分钟前
在VS2019编辑器环境中使用c++打造window服务程序基础框架详细步骤
c++·编辑器·服务程序
sheeta199817 分钟前
LeetCode 每日一题笔记 日期:2026.05.23 题目:1752. 检查数组是否经排序和轮转得到
笔记·算法·leetcode
是main不是漫19 分钟前
【数据结构--双向链表】从前有个节点,它想要两头讨好…
c语言·数据结构·链表