贪心思想之——最大子段和问题

题目描述:

数组中子段的最大总和。

例如,1 2 3 -5 4 3 -6 中的最大子段总和是 1 + 2 + 3 +( - 5)+ 4 + 3 = 8

输入格式:

第一行一个整数 nn。(1≤n≤100000)(1≤n≤100000)

第二行 nn 个整数 aiai​。(−10000≤ai≤10000)(−10000≤ai​≤10000)

输出格式:

一个整数表示最大子段和

贪心思想,非常重要!

我们首先要明确贪心的过程:两个变量,sum表示某个区间的区间和 ,mx表示sum每个形态 中的最大值。贪心思想为sum初始值为0,一直累加a[i],并用mx记录下sum的最大值如果sum小于0,就重新开始,因为负数加上一个数不如0加上那个数,当然我们必须要注意,在输入数组全部为负数的时候,输出最大(距离0最近)的负数。

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;


int main() {
	int n, mx = 0x80000000, a[100005];
	cin >> n;
	for (int i = 1; i <= n; i++) {
		cin >> a[i];
		mx = max(mx, a[i]); // 临时记录下最大值 
	}
	if (mx < 0) {
		cout << mx << endl; // 如果全部为负数,输出离0最近的数。 
		return 0;
	}
	mx = 0x80000000; // 重新初始化,新的意义为sum的最大形态 
	int sum = 0;
	for (int i = 1; i <= n; i++) {
		mx = max(mx, sum); // 更新 
		sum += a[i]; // 累加 
		if (sum < 0) // 当sum < 0,就把区间的左边更新,一切重新开始 
			sum = 0;
	}
	cout << mx << endl;
	return 0;
}

感谢阅读,如有错误或者建议请在评论区指出,进入我主页探索更多算法知识!

相关推荐
独处东汉36 分钟前
freertos开发空气检测仪之输入子系统结构体设计
数据结构·人工智能·stm32·单片机·嵌入式硬件·算法
乐迪信息39 分钟前
乐迪信息:AI防爆摄像机在船舶监控的应用
大数据·网络·人工智能·算法·无人机
放荡不羁的野指针43 分钟前
leetcode150题-滑动窗口
数据结构·算法·leetcode
BHXDML1 小时前
数据结构:(一)从内存底层逻辑理解线性表
数据结构
小龙报1 小时前
【C语言进阶数据结构与算法】单链表综合练习:1.删除链表中等于给定值 val 的所有节点 2.反转链表 3.链表中间节点
c语言·开发语言·数据结构·c++·算法·链表·visual studio
TracyCoder1232 小时前
LeetCode Hot100(13/100)——238. 除了自身以外数组的乘积
算法·leetcode
CoderCodingNo2 小时前
【GESP】C++五级练习题 luogu-P3353 在你窗外闪耀的星星
开发语言·c++·算法
Anastasiozzzz2 小时前
LeetCode Hot100 215. 数组中的第K个最大元素
数据结构·算法·leetcode
让我上个超影吧2 小时前
【力扣76】最小覆盖子串
算法·leetcode·职场和发展
近津薪荼2 小时前
优选算法——双指针5(单调性)
c++·学习·算法