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;
    }
};
相关推荐
南境十里·墨染春水11 分钟前
C++ 笔记 thread
java·开发语言·c++·笔记·学习
南境十里·墨染春水13 分钟前
C++ 笔记 高级线程同步原语与线程池实现
java·开发语言·c++·笔记·学习
瞎折腾啥啊24 分钟前
CMake FetchContent与ExternalProject
c++·cmake·cmakelists
三品吉他手会点灯1 小时前
STM32 VSCode 开发-C/C++的环境配置中,找不到C/C++: Edit Configurations选项
c语言·c++·vscode·stm32·单片机·嵌入式硬件·编辑器
逻辑驱动的ken1 小时前
Java高频面试考点场景题09
java·开发语言·数据库·算法·oracle·哈希算法·散列表
帅小伙―苏2 小时前
力扣42接雨水
前端·算法·leetcode
AI科技星2 小时前
精细结构常数α的几何本源:从第一性原理的求导证明、量纲分析与全域验证
算法·机器学习·数学建模·数据挖掘·量子计算
6Hzlia2 小时前
【Hot 100 刷题计划】 LeetCode 287. 寻找重复数 | C++ 数组判环 (快慢指针终极解法)
c++·算法·leetcode
MegaDataFlowers2 小时前
26.删除有序数组中的重复项
算法
Robot_Nav3 小时前
DPMPC-Planner:复杂静态环境与动态障碍物下的无人机实时轨迹规划框架
c++·无人机·mpc