leetcode 53. 最大子数组和

题目如下

数据范围

复制代码
法一
暴力解法: 生成前缀和数组用于迅速判断得到从i到j的子数组和。
时间复杂度O(n方)因为数组很大这个解法虽然可以但是容易超时。
法二
令f(n)是以n为结尾的最大子数组和,其中f(n) = max(f(n - 1) + nums[n],f(n))
很容易想到设置一个数组用于存储每个f(i)但是我们每次循环只需要使用上一个值所以可以用pre变量来节省内存。

通过代码

cpp 复制代码
class Solution {
public:
  int maxSubArray(vector<int>& nums) {
        int sum = nums[0];int pre = 0;
        for(const auto &n:nums) {
                pre = max(pre + n,n);
                sum = max(pre,sum);
        }
    return sum;

}
};
相关推荐
福楠14 小时前
模拟实现list容器
c语言·开发语言·数据结构·c++·list
老鼠只爱大米14 小时前
LeetCode算法题详解 1:两数之和
算法·leetcode·面试题·两数之和·two sum
欧阳天羲14 小时前
ML工程师学习大纲
学习·算法·决策树
lunatic714 小时前
CMake 常用内置变量说明
c++·cmake
海天一色y14 小时前
python--数据结构--链表
数据结构·链表
AI爱好者202014 小时前
智能优化算法2025年新书推荐——《智能优化算法及其MATLAB实例(第4版)》
开发语言·算法·matlab
三川69814 小时前
数据结构设计高频题目
数据结构·哈希算法·散列表
LYFlied14 小时前
【每日算法】LeetCode215. 数组中的第K个最大元素
前端·算法
2501_9418227514 小时前
从限流降载到全链路流控的互联网工程语法实践与多语言探索
leetcode·模拟退火算法
炽烈小老头14 小时前
【每天学习一点算法 2026/01/06】最小栈
学习·算法·leetcode