动态规划(算法竞赛、蓝桥杯)--斜率优化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;
}
相关推荐
欧了1111 小时前
洛谷P9240 [蓝桥杯 2023 省 B] 冶炼金属
职场和发展·蓝桥杯·洛谷·蓝桥杯大学b组c语言
大数据追光猿2 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!2 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉2 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生2 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
柠石榴2 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯
Leuanghing2 小时前
【Leetcode】11. 盛最多水的容器
python·算法·leetcode
qy发大财2 小时前
加油站(力扣134)
算法·leetcode·职场和发展
王老师青少年编程2 小时前
【GESP C++八级考试考点详细解读】
数据结构·c++·算法·gesp·csp·信奥赛
qy发大财2 小时前
柠檬水找零(力扣860)
算法·leetcode·职场和发展