LeetCode热题100——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 <= 10^5

  • -10^4 <= nums[i] <= 10^4

题解:

1.核心思想:(动态规划)

从左到右扫描时,时刻维护一个"当前子数组",并决定:

  • 如果加上当前数字能让子数组变大,就加上;
  • 如果加上反而变小,就丢掉前面的,从当前数字重新开始。

同时,每走一步,都记录下目前为止见到的最大和。

2.核心代码:

cpp 复制代码
pre = max(pre + x, x);
maxAns = max(maxAns, pre);
  • pre 表示:以当前元素结尾的连续子数组的最大和。(注意:必须包含当前元素)

  • maxAns 表示:全局最大和,初始设为数组的第一个元素(不能设为 0,详见下文的要点)。

答案:

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int pre=0;
        int maxAns=nums[0];
        for(int i=0;i<nums.size();i++){
            pre=max(pre+nums[i],nums[i]);
            maxAns=max(maxAns,pre);
        }
        return maxAns;
    }
};

要点:

1.为什么 maxAns 初始为 nums[0] 而不是 0?

如果数组全是负数,比如 [-5, -2, -1],最大子数组和应该是-1。但是如果 maxAns 初始为 0,那么 max(0, -5) = 0,会错误地返回 0。

相关推荐
Zevalin爱灰灰4 小时前
现代密码学 第二章——流密码【下】
算法·密码学
飞Link6 小时前
大模型长文本的“救命稻草”:深度解析 TurboQuant 与 KV Cache 压缩技术
算法
郝学胜-神的一滴6 小时前
深度学习优化核心:梯度下降与网络训练全解析
数据结构·人工智能·python·深度学习·算法·机器学习
Je1lyfish7 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
许彰午7 小时前
03-二叉树——从递归遍历到非递归实现
java·算法
Brilliantwxx7 小时前
【C++】 vector(代码实现+坑点讲解)
开发语言·c++·笔记·算法
叼烟扛炮8 小时前
C++第三讲:类和对象(中)
开发语言·c++·类和对象
KuaCpp8 小时前
C++新特性学习
c++·学习
墨染千千秋9 小时前
C/C++ Keywords
c语言·c++
ximu_polaris9 小时前
设计模式(C++)-行为型模式-中介者模式
c++·设计模式·中介者模式