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。

相关推荐
2301_78866240几秒前
C++与微服务架构
开发语言·c++·算法
你怎么知道我是队长3 分钟前
C语言---排序算法3---插入排序法
c语言·算法·排序算法
项目申报小狂人16 分钟前
中科院1区SCI-哲学命题优化算法Philosophical proposition optimizer-附Matlab免费代码
linux·算法·matlab
rit843249919 分钟前
基于光流场的 Demons 算法
算法
哈哈不让取名字19 分钟前
C++代码冗余消除
开发语言·c++·算法
棱镜Coding23 分钟前
LeetCode-Hot100 27.合并两个有序链表
算法·leetcode·链表
2301_7657031434 分钟前
C++中的策略模式应用
开发语言·c++·算法
TGITCIC34 分钟前
RAG不是魔法,是工程:从知识库到企业部署的硬核实践
人工智能·算法·机器学习·rag·ai agent·ai开发·rag增强检索
求梦82041 分钟前
【力扣hot100题】两两交换链表中的节点(25)
算法·leetcode·链表
passxgx42 分钟前
12.1 均值、方差与概率
算法·均值算法·概率论