蓝桥杯备考:动态规划dp之最大子段和

和之前的顺序一下

step1:

我们先确定状态表示 f[i]表示以i为终点的最大子段和

step2:确定状态表示方程

f[i]=f[i-1]+a[i],仅仅是这样吗?no absolutely not

我们假如以i-1为终点的最大字段和是负无穷,而a[i]是一个正数,那么 f[i-1]+a[i]肯定是比a[i]本身要小的,

所以我们真实的状态方程应该是f[i]=max(a[i],a[i]+f[i-1])

step3;初始化

我们数组下标从1开始,那么初始化f[1] 的时候 f[1]应该等于a[i] f[i-1]的值不应该影响最终结果

所以刚开始我们数组要初始化成0

为什么从下标1开始,这是为了防止越界

cpp 复制代码
#include <iostream>
using namespace std;
const int N = 2e5+10;
typedef long long LL;
LL f[N];
LL a[N];
LL n;
int main()
{
	cin >> n;
	for(LL i = 1;i<=n;i++)
	{
		cin >> a[i];
	}
	LL ret = -1e9;
	for(LL i = 1;i<=n;i++)
	{
		f[i] = max(f[i-1]+a[i],a[i]);
		ret = max(f[i],ret);
	}
	cout << ret << endl;
	
	
	
	
	
	return 0;
}

当然我们是可以对空间做一些优化的,比如说,我们不必开一个a[N]数组,我们有一个f[N]数组就足够了,我们用一个临时变量输入n次代表每个数就行了

cpp 复制代码
#include <iostream>
using namespace std;
const int N = 2e5+10;
typedef long long LL;
LL f[N];
LL a[N];
LL n;
int main()
{
	LL ret = -1e9;
	cin >> n;
	LL x;
	for(LL i = 1;i<=n;i++)
	{
		cin >> x;
		f[i] = max(f[i-1]+x,x);
		ret = max(f[i],ret); 
	}
	cout << ret << endl;
	
	
	
	
	
	return 0;
}
相关推荐
ChoSeitaku4 小时前
NO.30十六届蓝桥杯备战|C++输入输出|单组测试用例|多组测试用例|isalpha|逗号表达式(C++)
c++·蓝桥杯·测试用例
阿巴~阿巴~5 小时前
C/C++蓝桥杯算法真题打卡(Day4)
数据结构·c++·算法·蓝桥杯
互联网杂货铺6 小时前
Web自动化测试之Selenium详解
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
程序员杰哥7 小时前
2025最新软件测试面试八股文(含答案+文档)
自动化测试·软件测试·python·功能测试·面试·职场和发展·测试用例
bee-y8 小时前
力扣hot100——多维动态规划
算法·leetcode·动态规划
爱编程的小赵8 小时前
蓝桥杯备赛:一道数学题(练思维(同余的应用))
职场和发展·蓝桥杯
BingLin-Liu10 小时前
蓝桥杯备考:动态规划路径类DP之矩阵的最小路径和
矩阵·蓝桥杯·动态规划
Tom Boom10 小时前
1.11.信息系统的分类【DSS】
人工智能·算法·机器学习·职场和发展·分类·数据挖掘·系统架构
邴越11 小时前
回文子序列问题解题模板
算法·leetcode·职场和发展
独行soc12 小时前
2025年渗透测试面试题总结-长某亭科技-安全服务工程师(一面)(题目+回答)
科技·安全·面试·职场和发展·红蓝攻防·护网·2025