最大子段和(前缀和解决)

来自于洛谷的一道题,链接附上

最大子段和https://www.luogu.com.cn/problem/P1115


问题定义:给出一个长度为 n 的序列 a,选出其中连续且非空的一段使得这段和最大

以以下样本为例

复制代码
2 -4 3 -1 2 -4 3

当我们想求第i个位置的最大和

我们的前缀和数组为Presum,数组以1开始我们可以将其转化为

此时我们可以把问题转化为求下方式子的最大值

复制代码
presum[i]-presum[x];//1<=x<=n-1

此时我们可以遍历整个前缀和数组,减去最小的presumx,从而获得最大的max.


相关代码

cpp 复制代码
#include<iostream>
using namespace std;
typedef long long LL;
const int N = 2e5 + 10;
int n;
LL f[N];
int main()
{
	cin >> n;
	for (int i = 1;i <= n;i++)
	{
		int x;cin >> x;
		f[i] = f[i - 1] + x;
	}
	LL ret = -1e10;
	LL premin = 0;
	for (int i = 1;i <= n;i++)
	{
		ret = max(ret, f[i] - premin);
		premin = min(premin, f[i]);
	}
	cout << ret;
	return 0;
}
相关推荐
khalil10208 小时前
代码随想录算法训练营Day-58 图论08 | 拓扑排序精讲、dijkstra(朴素版)精讲
c++·算法·图论·dijkstra·拓扑排序·prim·最短距离
吃好睡好便好8 小时前
矩阵的乘法运算
数据结构·人工智能·学习·线性代数·算法·matlab·矩阵
Ricky05538 小时前
RF-DETR:实时检测变换器(transformers)的神经架构搜索(美国2025.12研究)
图像处理·人工智能·算法
Qhappy9 小时前
某里v2反混淆 codec 化路上踩到的两个隐蔽坑:被清零的 salt 与 opaque loop bound
javascript·算法
Hello world.Joey9 小时前
吴恩达深度学习基础
人工智能·深度学习·神经网络·opencv·算法·机器学习·计算机视觉
水木流年追梦9 小时前
大模型入门-大模型优化方法1
人工智能·学习·算法·机器学习·正则表达式
lynnlovemin9 小时前
【信息学竞赛专题】滑动窗口(尺取法)超全详解|C++模板+经典例题+避坑指南
开发语言·c++·算法·滑动窗口·信息学竞赛
澈2079 小时前
动态规划入门:从斐波那契到爬楼梯
c++·算法
x_xbx10 小时前
LeetCode:739. 每日温度
算法·leetcode·职场和发展