动态规划(算法竞赛、蓝桥杯)--斜率优化DP打印文章

1、B站视频链接:E51【模板】斜率优化DP 打印文章_哔哩哔哩_bilibili

题目链接:Problem - 3507

cpp 复制代码
#include <bits/stdc++.h> 
using namespace std;
typedef long long LL;
const int N=500010;
int n,m,q[N];
LL s[N],f[N];

double sl(int i,int j){
	return (double)(f[i]+s[i]*s[i]-f[j]-s[j]*s[j])
				/(s[i]==s[j]?1e-9:s[i]-s[j]);
}
int main(){
	while(~scanf("%d%d",&n,&m)){
		for(int i=1;i<=n;i++){
			scanf("%lld",&s[i]);
			s[i]+=s[i-1];
		}
	}
	int h=1,t=0;
	for(int i=1;i<=n;i++){
		while(h<t&&sl(i-1,q[t])<=sl(q[t],q[t-1]))t--;
		q[++t]=i-1;
		while(h<t&&sl(q[h+1],q[h])<=2*s[i])h++;
		int j=q[h];
		f[i]=f[j]+(s[i]-s[j])*(s[i]-s[j])+m;
	}
	printf("%lld\n",f[n]);
	return 0;
}
相关推荐
地平线开发者9 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮10 小时前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者10 小时前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考10 小时前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx14 小时前
CART决策树基本原理
算法·机器学习
Wect14 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱15 小时前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
Gorway21 小时前
解析残差网络 (ResNet)
算法
拖拉斯旋风21 小时前
LeetCode 经典算法题解析:优先队列与广度优先搜索的巧妙应用
算法
Wect21 小时前
LeetCode 207. 课程表:两种解法(BFS+DFS)详细解析
前端·算法·typescript