leetcode hot100刷题日记——7.最大子数组和

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        //方法一:动态规划
        //dp[i]表示以i下标结尾的数组的最大子数组和
        //那么在i=0时,dp[0]=nums[0]
        //之后要考虑的就是我们要不要把下一个数加进来,如果下一个数加进来会使结果变大那就加进来
        //但要是下一个数加进来之后,还不如这个数单独大,那我们就舍弃前面的子数组和,直接用单独这个数,即:
        //dp[i]=max(dp[i-1]+nums[i],nums[i])
        //什么情况下"下一个数加进来之后,还不如这个数单独大"?
        //dp[i-1]为负数的时候
        // int n=nums.size();
        // vector<int>dp(n);
        // dp[0]=nums[0];
        // int maxx=nums[0];
        // for(int i=1;i<n;i++){
        //     dp[i]=max(dp[i-1],0)+nums[i];
        //     maxx=max(dp[i],maxx);
        // }
        // return maxx;

    //方法2:前缀和+贪心
    //最大子数组和=max(所有当前前缀和-最小前缀和)
    //为什么只需要维护最小前缀和呢?
    //因为最大子数组和这个问题要看的是连续部分!
    //你如果求最大前缀和-最小前缀和
    //那么有可能最大前缀和比最小前缀和短!
    //eg. 5 4 3 -2 -1 -5
    //最大前缀和是5+4+3=12
    //最小前缀和是5+4+3-2-1-5=4
    //最大前缀和-最小前缀和=8
    //但是不对啊!实际上最大子数组和是5+4+3=12啊!
    //所以最小前缀和初始化值为0
    int n=nums.size();
    if(n==1)
        return nums[0];
    int ans=INT_MIN;
    int minn=0;
    int sum=0;
    for(int i=0;i<n;i++){
        sum+=nums[i];
        ans=max(ans,sum-minn);
        minn=min(minn,sum);
    }
    return ans;

    }
};

时间复杂度:O(N)

空间复杂度:

方法一是O(N)

方法二是O(1)

相关推荐
文火冰糖的硅基工坊1 分钟前
[人工智能-大模型-57]:模型层技术 - 软件开发的不同层面(如底层系统、中间件、应用层等),算法的类型、设计目标和实现方式存在显著差异。
人工智能·算法·中间件
鱼儿也有烦恼6 分钟前
快速学完 LeetCode top 1~50 [特殊字符]
java·算法·leetcode·1024程序员节
独自破碎E7 分钟前
LeetCode 380: O(1) 时间插入、删除和获取随机元素
java·算法·leetcode
Brookty16 分钟前
【算法】前缀和(二)使用
java·学习·算法·前缀和·动态规划·1024程序员节
不良人龍木木30 分钟前
云图-地基云图
图像处理·算法·计算机视觉·1024程序员节
RTC老炮32 分钟前
webrtc弱网-PccNetworkController类源码分析与算法原理
网络·算法·webrtc
Swift社区38 分钟前
LeetCode 406 - 根据身高重建队列
算法·leetcode·1024程序员节
敲上瘾40 分钟前
背包dp——动态规划
c++·算法·动态规划
京东零售技术1 小时前
大模型时代的广告营销变革与实践
算法
侯小啾6 小时前
【03】C语言 强制类型转换 与 进制转换
c语言·数据结构·算法