算法:最大子数组和

这道题使用的是动态规划思想(Kadane算法),目标是在数组中找到一个连续子数组,使这个子数组元素之和最大。

算法从数组的第一个元素开始向后遍历,并维护两个变量:

一个变量表示"以当前元素结尾的连续子数组的最大和"。

另一个变量表示"遍历到目前为止出现过的最大连续子数组和"。

对于数组中的每一个元素,都要思考一个问题:

当前元素应该接到前面的连续子数组后面,还是自己重新开始形成一个新的连续子数组?

具体来说:

如果前面累计得到的和再加上当前元素,比当前元素本身还大,那么说明前面的部分对结果有贡献,应该继续保留,把当前元素接在后面。

如果前面累计得到的和再加上当前元素,还不如当前元素本身大,那么说明前面的部分已经成为负担,应该舍弃之前的连续子数组,从当前元素重新开始计算。

因此,每遍历到一个新元素时,都计算:

继续延伸之前的连续子数组得到的和;

从当前元素重新开始得到的和;

取两者中的较大值,作为"以当前元素结尾的最大连续子数组和"。

随后,再将这个结果与历史记录中的最大值进行比较:

如果当前得到的连续子数组和更大,就更新全局最大值;

否则保持原来的最大值不变。

整个过程只需要遍历数组一次。

从本质上看,这个算法利用了这样一个规律:

如果一个连续子数组的和已经变成负数,那么它只会拖累后面的结果,因此没有必要继留;

如果它是正数,则可以帮助后面的元素获得更大的和,因此应该保留。

最终,当遍历结束时,记录下来的全局最大值就是整个数组中的最大连续子数组和。

cpp 复制代码
int maxSubArray(vector<int>& nums) {
        
        int pre=0,maxAns=nums[0];
        for(const auto &x:nums)
        {

            pre=max(pre+x,x);
            maxAns=max(maxAns,pre);
        }
        return maxAns;
    }
相关推荐
吃着火锅x唱着歌1 小时前
LeetCode 3829.设计共享出行系统
算法·leetcode·职场和发展
炸薯条!1 小时前
二叉树的链式表示
数据结构·算法
CHHH_HHH1 小时前
【C++】二叉搜索树全面升级,深度剖析AVL树
开发语言·数据结构·c++·算法·stl
Mumu12181 小时前
P3211 [HNOI2011] XOR和路径
算法
高一学习c++会秃头吗1 小时前
页面置换算法实现
算法
yuanyuan2o21 小时前
Transformers NLP 任务:阅读理解问答
人工智能·算法·自然语言处理·nlp·github
菜菜的顾清寒1 小时前
力扣HOT100(52)动态规划 - 最长递增子序列
算法·leetcode·动态规划
WBluuue2 小时前
数据结构与算法:树上启发式合并
数据结构·c++·算法·启发式算法
x_xbx2 小时前
LeetCode:20. 有效的括号
算法·leetcode·职场和发展