Leetcode53. 最大子数组和(HOT100)

链接

我的解法:

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int n = nums.size();
        int res = INT_MIN;
        vector<int> f(n+1,0);
        for(int i = 1;i<=n;i++){
            f[i] = max(f[i-1]+nums[i-1],nums[i-1]);
            res = max(res,f[i]);
        }
        return res;
    }
};

f[i]表示以nums[i]结尾的子数组的和的最大值。

对于前i个数,要求最大和,要么就是前i-1个数求出来的最大和,要么是第i个数本身就是这i个数中的最大和。


更好的解法:

cpp 复制代码
// class Solution {
// public:
//     int maxSubArray(vector<int>& nums) {
//         int res = INT_MIN;
//         for(int i = 0,last = 0;i<nums.size();i++){
//             last = max(nums[i],nums[i]+last);
//             res = max(res,last);
//         }
//         return res;

//     }
// };

空间复杂度是O(1)的,使用last来存储f[i-1],每次更新last。

相关推荐
神经美学_茂森34 分钟前
【通俗理解】神经网络中步长缩小的奥秘:优化算法与卷积操作的影响
网络·神经网络·算法
jay丿2 小时前
正则表达式
服务器·mysql·算法·正则表达式·php
重生之我在VS写bug5 小时前
【C++知识总结2】C++里面的小配角cout和cin
数据结构·c++·算法
HUT_Tyne2655 小时前
力扣--LCR 141.训练计划III
算法·leetcode·职场和发展
pzn25066 小时前
蓝桥杯练习题
c++·算法·蓝桥杯
奶茶戒断高手7 小时前
【CSP CCF记录】201903-2第16次认证 二十四点
数据结构·c++·算法
xxxmmc7 小时前
Leetcode 290 word Pattern
算法·leetcode·hashmap双映射
羽墨灵丘7 小时前
0-1背包问题(1):贪心算法
算法·贪心算法
shepherd枸杞泡茶8 小时前
C# 数据结构之【队列】C#队列
开发语言·数据结构·c#