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;

}
};
相关推荐
大佬,救命!!!5 小时前
C++函数式策略模式中配置修改
c++·学习笔记·迭代加深·企业级·函数式策略模式·多文件编译环境·json环境配置修改
Chiang木5 小时前
C++进阶:coroutine 协程
开发语言·c++·协程
蕓晨5 小时前
数据结构 图 的邻接表建立
数据结构·c++
渡我白衣5 小时前
深入 Linux 内核启动:从按下电源到用户登录的全景解剖
java·linux·运维·服务器·开发语言·c++·人工智能
甄心爱学习5 小时前
数据挖掘11-分类的高级方法
人工智能·算法·分类·数据挖掘
byte轻骑兵6 小时前
Rust赋能Android蓝牙协议栈:从C++到安全高效的重构之路
android·c++·rust
爪哇部落算法小助手6 小时前
每日两题day44
算法
qq_401700416 小时前
嵌入式常用宏定义
数据结构
不穿格子的程序员7 小时前
从零开始写算法——二分-搜索二维矩阵
线性代数·算法·leetcode·矩阵·二分查找
龙泉寺天下行走7 小时前
MinGW-w64 工具链(GCC 编译器) 的不同构建版本的区别
c++