【算法与数据结构】53、LeetCode最大子数组和

文章目录

所有的LeetCode题解索引,可以看这篇文章------【算法和数据结构】LeetCode题解

一、题目

二、解法

思路分析:程序一共两个变量,一个result一个count。result用来记录最终的结果,count记录当前的子序列和。如果说当前和(count)大于上次的最大和(result),就更新result。每当当前和小于0是就将count重置为0,因为小于0的和不会增加count的值可以直接舍去。例如,[-2,1,-3,4,-1,2,1,-5,4],-2+1=-1。那么最大和的连续子数组可以从1开始计算,-2直接不用。

程序如下:

cpp 复制代码
class Solution {
public:
	int maxSubArray(vector<int>& nums) {
		int result = INT32_MIN;		// 32位最小值
		int count = 0;
		for (int i = 0; i < nums.size(); i++) {
			count = count + nums[i];
			if (count > result) result = count;
			if (count < 0) count = 0;
		}
		return result;
	}
};

复杂度分析:

  • 时间复杂度: O ( n ) O(n) O(n)。
  • 空间复杂度: O ( 1 ) O(1) O(1)。

三、完整代码

cpp 复制代码
# include <iostream>
# include <vector>
using namespace std;

class Solution {
public:
	int maxSubArray(vector<int>& nums) {
		int result = INT32_MIN;		// 32位最小值
		int count = 0;
		for (int i = 0; i < nums.size(); i++) {
			count = count + nums[i];
			if (count > result) result = count;
			if (count < 0) count = 0;
		}
		return result;
	}
};
int main() {
	vector<int> nums = { -2,1,-3,4,-1,2,1,-5,4 };
	Solution s1;
	int result = s1.maxSubArray(nums);
	cout << result << endl;
	system("pause");
	return 0;
}

end

相关推荐
qq_4017004126 分钟前
顺序、二分、插值、斐波那契查找算法
数据结构·算法·排序算法
x_xbx26 分钟前
LeetCode:26. 删除有序数组中的重复项
数据结构·算法·leetcode
WitsMakeMen27 分钟前
RoPE 算法原理?算法为什么只和相对位置有关
人工智能·算法·llm
0 0 01 小时前
CCF-CSP 38-4 月票发行【C++】考点:动态规划DP+矩阵快速幂
c++·算法·动态规划·矩阵快速幂
北漂Zachary1 小时前
Mysql中使用sql语句生成雪花算法Id
sql·mysql·算法
aini_lovee1 小时前
MATLAB圆锥滚子轴承滚子参数分析程序
人工智能·算法·matlab
_olone1 小时前
牛客每日一题:显生之宙(Java)
java·开发语言·算法·牛客
嫂子开门我是_我哥2 小时前
心电域泛化研究从0入门系列 | 第二篇:心电信号预处理全攻略——扫清域泛化建模的第一道障碍
人工智能·算法·ecg
wefg12 小时前
【算法】算数基本定理、分解质因数
算法
j_xxx404_2 小时前
力扣困难算法精解:串联所有单词的子串与最小覆盖子串
java·开发语言·c++·算法·leetcode·哈希算法