[模板] 斜率优化Dp详解

本文介绍了斜率优化DP的概念,它扩展了单调队列优化,用于解决动态规划中涉及平方项的状态转移方程。通过引例分析HDU3507题目,解释了如何利用斜率优化将O(n^2)的时间复杂度降低到O(n),并提供了核心算法代码。此外,还列举了一些经典例题,帮助读者深入理解斜率优化的应用。
摘要由CSDN通过智能技术生成

声明!!!

本文有误,请勿轻易阅读本文或复制代码,内容将于近期更新并上传至我的独立博客,敬请谅解。
update:本文已重写,请访问这里,谢谢。


算法简介

今天xinyue讲了斜率优化,全程懵逼,居然还有这么牛逼的东西。
于是与achen讨论了一下,总结一些东西。
斜率优化Dp其实是单调队列的推广,单调队列、旋转卡壳、斜率优化都利用了单调性降低时间复杂度。


算法简介

举个例子
有些动规状态转移方程可以写成
f[i]=min/max{f[j]+…+x[i]},省略号中只有与j有关的变量。
我们就可以用单调队列进行优化,使O(n^2)降为O(n)
但是对于这一类的方程:
f[i]=min/max{f[j]+(x[i]-x[j])^2}
展开后得到
f[i]=min/max{f[j]+x[i]2+x[j]2-2*x[i]*x[j]}
红色部分不仅有j相关的量,还有与i有关的量,从而使单调队列失效。
此时我们就需要用到斜率优化。


引例

hdu3507
题目大意:
给出N个单词,每个单词有个非负权值Ci,现要将它们分成连续的若干段,每段的代价为此段单词的权值和,还要加一个常数M,即(∑Ci)^2+M。现在想求出一种最

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值