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。

相关推荐
严文文-Chris25 分钟前
【监督学习常用算法总结】
学习·算法
feifeigo12327 分钟前
电池的荷电状态(SOC)估计
算法
博语小屋1 小时前
力扣 15.三数之和(medium)(双指针)
算法·leetcode·职场和发展
无敌最俊朗@1 小时前
双指针-力扣hot100-移动零.283
算法·leetcode·职场和发展
练习时长一年1 小时前
LeetCode热题100(腐烂的橘子)
算法·leetcode·职场和发展
Тиё Сиротака7 小时前
红包分配算法的严格数学理论与完整实现
算法
potato_may8 小时前
链式二叉树 —— 用指针构建的树形世界
c语言·数据结构·算法·链表·二叉树
Mz12218 小时前
day07 和为 K 的子数组
数据结构
java修仙传8 小时前
每日一题,力扣560. 和为 K 的子数组
算法·leetcode
ada7_9 小时前
LeetCode(python)——148.排序链表
python·算法·leetcode·链表