leetcode 53.最大子数组和

思路:dp。

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

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

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

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

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

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

还有,就是在处理的时候,需要初始化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;
    }
};
相关推荐
凯瑟琳.奥古斯特21 分钟前
力扣1235:加权区间调度最优解
java·python·算法·leetcode·职场和发展
耶叶37 分钟前
餐厅出入最少人数问题:贪心算法
算法·贪心算法
gihigo199841 分钟前
基于小波框架与稀疏表示的SAR图像目标识别系统(MATLAB实现)
算法
吴可可1231 小时前
CAD2004自定义实体开发环境配置
c++·算法
装不满的克莱因瓶1 小时前
矩阵的主成分是什么?主成分分析(PCA)又能做什么?
人工智能·线性代数·算法·机器学习·ai·矩阵·pca
大菜菜小个子1 小时前
template<typename T>使用
java·开发语言·算法
L_09071 小时前
【C++】C++11 新特性
开发语言·c++
Fanfanaas1 小时前
C++ 继承
java·开发语言·jvm·c++·学习·算法
lqqjuly1 小时前
模型合并与融合:理论、算法与可运行实现—从损失曲面几何到多模型融合
算法
memcpy01 小时前
LeetCode 2144. 打折购买糖果的最小开销【贪心】
算法·leetcode·职场和发展