leetcode-53. 最大子数组和
创始人
2025-05-31 23:29:12
0

一、动态规划

因为我们一共要统计n^2的区间,枚举一遍求最大值比较慢,因此我们可以考虑将n^2个区间分成n类,第一类以a[0]为结尾,第二类以a[1]结尾,....以此类推。然后我们对每一类的最大值取个max就可以了。

定义f[i]是所有以nums[i]为结尾的区间中的最大和,由这个定义出发,我们看看f[i]与f[i-1]有什么递推关系。

我们使用集合划分的思想,下图中的椭圆表示所有以i为结尾的区间。所有以i为结尾的区间可以分成两大类,第一类表示区间长度至少是2,第二类表示区间长度为1(即这个区间内只有nums[i]本身)。f[i]为这两类各自的最大值再取max。

我们来看一下第一类区间是什么(以i结尾,并且长度大于等于2的区间)

发现这一类的区间都是包含nums[i]的,所以我们要想在里面找最大值的话,就要让前面那一部分最大,前面这一部分其实就是所有以nums[i - 1]为结尾的区间,最大值为f[i - 1],所以第一类区间的最大值为f[i - 1] + nums[i]

综上,f[i] = max{nums[i], f[i - 1] + nums[i]}

时间复杂度:

  • 状态数为O(n),状态转移时间为O(1),因此,总的时间复杂度为O(n)。

空间复杂度:

  • 需要开辟额外的数组f[n],因此,空间复杂度为O(n)
class Solution {
public:int maxSubArray(vector& nums) {int n = nums.size();vector f(n);int res = nums[0];f[0] = nums[0];for (int i = 1; i < n; ++ i){f[i] = max(nums[i], f[i - 1] + nums[i]);res = max(f[i], res);}return res;}
};

二、分治

1、对于一个区间[l, r],维护四个值,分别是:

总和sum,非空最大子段和s,前缀非空最大子段和ls,后缀非空最大子段和rs。

2、分别递归左右子区间。

3、合并时:

  • 对于当前的sum,是左右子区间的sum之和。
  • 对于当前的s,是三种情况取最大值:左区间的s,右区间的s,左区间的rs加上右区间的ls。
  • 对于当前的ls,是两种情况取最大值:左区间的ls,左区间的sum加上右区间的ls。
  • 对于当前的rs,是两种情况取最大值:右区间的rs,右区间的sum加上左区间的rs。

4、合并后返回递归结果。

时间复杂度:

  • 由主定理T(n) = 2T(n / 2) + O(1),解出总的时间复杂度为O(n)

空间复杂度:

  • 需要开辟系统栈用于递归,O(logn)
class Solution {
public:struct Node {int sum, s, ls, rs;};Node build(vector& nums, int l, int r) {if (l == r) return Node {nums[l], nums[l], nums[l], nums[l]};int mid = l + r >> 1;Node L = build(nums, l, mid);Node R = build(nums, mid + 1, r);Node res;res.sum = L.sum + R.sum;res.s = max(max(L.s, R.s), L.rs + R.ls);res.ls = max(L.ls, L.sum + R.ls);res.rs = max(R.rs, L.rs + R.sum);return res;}int maxSubArray(vector& nums) {Node res = build(nums, 0, nums.size() - 1);return res.s;}
};

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...