leetcode 53.最大子数组和

思路:dp。

虽然说是很基础的DP题,但是作者并没有搞透彻这道题,所以温故而知新,再次刷一次leetcode上的这种类型的题。

首先我们需要看清题目,这里说的是连续子数组,而不是子序列,我们需要注意的就是这道题和子序列的题是很相似的,就比如前面说过的哪个最长递增子序列一样,我们需要借用那里的思想,对于以...为结尾进行考虑。

这里我们的状态方程设为dp[i],就代表着我们以nums[i]为结尾的最大连续子序列和。好了,问题就是怎么进行递推操作。

当我们以某一个数为结尾的时候,我们这个时候已经把后面的的数的最大子序列和求出来了,所以我们需要考虑这样一个问题:我们当前的数加上后面已经计算出来的最大子序列和,结果是变小了还是变大了?如果我们加的是负数,那当然是变小了,但是如果说是正数,那么我们就需要在本数的基础上再加上后面的连续和。

这样判断出来就是结果了。

注意:我们需要注意到,求出来每一个数作为尾的最大连续和之后,我们需要求出来一个最大值,这个时候就必须从中选出一个最大值来,所以需要处理一下。

还有,就是在处理的时候,需要初始化dp数组,然后,变量res也需要初始化为很小数,因为可能是负数,所以需要赋值一个很小的数。

复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int dp[100010];
        memset(dp,-2e9,sizeof dp);
        dp[0]=nums[0];
        if(nums.size()==1)
        return nums[0];
        for(int i=1;i<nums.size();i++){
            if(dp[i-1]<=0)
            dp[i]=nums[i];
            else
            dp[i]=dp[i-1]+nums[i];
        }
        int res=-2e9;
        for(int i=0;i<nums.size();i++){
            res=max(res,dp[i]);
        }
        return res;
    }
};
相关推荐
陌路207 小时前
C23构造函数与析构函数
开发语言·c++
_OP_CHEN8 小时前
C++进阶:(二)多态的深度解析
开发语言·c++·多态·抽象类·虚函数·多态的底层原理·多态面试题
mount_myj9 小时前
敏感信息屏蔽(一)【java】
java·算法·极课堂
金色熊族9 小时前
装饰器模式(c++版)
开发语言·c++·设计模式·装饰器模式
先做个垃圾出来………9 小时前
偏移量解释
数据结构·算法
Dream it possible!10 小时前
LeetCode 面试经典 150_链表_旋转链表(64_61_C++_中等)
c++·leetcode·链表·面试
FanXing_zl10 小时前
基于整数MCU的FOC控制定标策略深度解析
单片机·嵌入式硬件·mcu·算法·定点运算·q15
立志成为大牛的小牛10 小时前
数据结构——三十三、Dijkstra算法(王道408)
数据结构·笔记·学习·考研·算法·图论
地平线开发者11 小时前
mul 与 reduce_sum 的优化实例
算法·自动驾驶
坚持编程的菜鸟11 小时前
LeetCode每日一题——Pow(x, n)
c语言·算法·leetcode