hdu3507,斜率优化dp

斜率优化\(dp\)入门题。

\(ProblemLink\)

先从\(n^2\)的\(dp\)开始

设\(S_i=\sum_{i=1}^n a_i\)

\(f_i\)为输出前\(i\)个的最小代价。

显然有\(f_i=min(f_j+(S_i-S_j)^2+M)(j<k)\)

考虑对于点i。j比k\((j>k)\)更优当且仅当

\(f_j+(S_i-S_j)^2<f_k+(S_i-S_k)^2\)

\(f_j+S_j^2-2S_iS_j<f_k+S_k^2-2S_iS_k\)

\((f_j+S_j^2)-(f_k+S_k^2)<2Si(S_j-S_k)\)

即\(\huge \frac {(f_j+S_j^2)-(f_k+S_k^2)}{(S_j-S_k)}<2Si\)

不妨设左式为\(P(j,k)\)

也就是说

如果\(P(j,k)<2Si\),那么\(j\)就比\(k\)更优。

我们发现如果把\(f_i+S_i^2\)这个东西看做\(y\),\(S_i\)看做\(x\)

式子就变成了这样

\(\huge \frac{y_j-y_k}{x_j-x_k}<2Si\)

于是我们可以把每个决策点想象一个在二维平面直角坐标系上的点(\(x\),\(y\))。

这有什么用呢?

我们发现,对于\(i\)来说,最优的决策就是那个斜率最小的点。

我们就可以维护一个斜率递增的下凸壳,每次加入时更新。

因为这里\(Si\)是单调递增的,用单调队列就可以维护了。

否则就在凸壳上二分,找到小于\(2Si\)的最近的点。

/*
@Date    : 2019-07-31 08:27:46
@Author  : Adscn ([email protected])
@Link    : https://www.cnblogs.com/LLCSBlog
*/
#include<bits/stdc++.h>
using namespace std;
#define IL inline
#define RG register
#define gi getint()
#define gc getchar()
#define File(a) freopen(a".in","r",stdin);freopen(a".out","w",stdout)
IL int getint()
{
    RG int xi=0;
    RG char ch=gc;
    bool f=0;
    while(ch<'0'||ch>'9')ch=='-'?f=1:f,ch=gc;
    while(ch>='0'&&ch<='9')xi=(xi<<1)+(xi<<3)+ch-48,ch=gc;
    return f?-xi:xi;
}
template<typename T>
IL void pi(T k,char ch=0)
{
    if(k<0)k=-k,putchar('-');
    if(k>=10)pi(k/10,0);
    putchar(k%10+'0');
    if(ch)putchar(ch);
}
const int N=5e5+7;
int s[N];
int f[N];
inline int sqr(int i){return i*i;}
inline double X(int j,int k)
{
    return (f[j]+sqr(s[j])-f[k]-sqr(s[k]));
}
inline double Y(int j,int k)
{
    return (s[j]-s[k]);
}
int main(void)
{
    int n,m;
    while(cin>>n>>m)
    {
        s[0]=0;
        for(int i=1;i<=n;++i)s[i]=gi;
        for(int i=1;i<=n;++i)s[i]+=s[i-1];
        int l=1,r=0;
        static int Q[N*2];
        Q[++r]=0;
        for(int i=1;i<=n;++i)
        {
            while(l<r&&X(Q[l+1],Q[l])<=2*s[i]*Y(Q[l+1],Q[l]))++l;
            f[i]=f[Q[l]]+sqr(s[i]-s[Q[l]])+m;
            while(l<r&&X(i,Q[r])*Y(Q[r],Q[r-1])<=X(Q[r],Q[r-1])*Y(i,Q[r]))--r;
            Q[++r]=i;
        }
        cout<<f[n]<<endl;
    }
    return 0;
}

原文地址:https://www.cnblogs.com/LLCSBlog/p/11274535.html

时间: 2024-10-07 17:46:58

hdu3507,斜率优化dp的相关文章

hdu3507之斜率优化DP入门

Print Article Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others) Total Submission(s): 4780    Accepted Submission(s): 1437 Problem Description Zero has an old printer that doesn't work well sometimes. As it is antiqu

HDU3507 Print Article(经典斜率优化dp)

一道很老的斜率优化dp 斜率优化看上去很难,其实是有技巧的 . 对于dp题目,如果你想优化他,一定要先列出朴素的表达式并观察性质 对于本题我们可以发现,如果要更新dp[i],我们就要从前面找到dp[j]+(s[i]-s[j])^2+m的最小值,其中s是前缀和 我们就可以猜测,一定有很多不可能转移的内容,我们应该如何删除它从而降低复杂度. 那么我们假设k<j,当i出现之后,k就不可能作为答案,那么这些k在i处满足的性质就是 dp[j]+(s[i]-s[j])^2+m<=dp[k]+(s[i]-s

bzoj-4518 4518: [Sdoi2016]征途(斜率优化dp)

题目链接: 4518: [Sdoi2016]征途 Description Pine开始了从S地到T地的征途. 从S地到T地的路可以划分成n段,相邻两段路的分界点设有休息站. Pine计划用m天到达T地.除第m天外,每一天晚上Pine都必须在休息站过夜.所以,一段路必须在同一天中走完. Pine希望每一天走的路长度尽可能相近,所以他希望每一天走的路的长度的方差尽可能小. 帮助Pine求出最小方差是多少. 设方差是v,可以证明,v×m^2是一个整数.为了避免精度误差,输出结果时输出v×m^2. In

[bzoj 1911][Apio 2010]特别行动队(斜率优化DP)

题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1911 分析: 首先可以的到裸的方程f[i]=max{f[j]+a*(Si-Sj)^2+b*(Si-Sj)+c} 0<j<i 简化一下方程,我们知道对于一次项,最后结果肯定是b*Sn 所以可以写成f[i]=max{f[j]+a*(Si-Sj)^2+c} 0<j<i 我们不妨设0<x<y<i,且x比y优 即f[x]+a*(Si-Sx)^2+c>f[y]+a*

hdu 2993 MAX Average Problem (斜率优化dp入门)

MAX Average Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 5855    Accepted Submission(s): 1456 Problem Description Consider a simple sequence which only contains positive integers as

bzoj-1096 1096: [ZJOI2007]仓库建设(斜率优化dp)

题目链接: 1096: [ZJOI2007]仓库建设 Description L公司有N个工厂,由高到底分布在一座山上.如图所示,工厂1在山顶,工厂N在山脚.由于这座山处于高原内陆地区(干燥少雨),L公司一般把产品直接堆放在露天,以节省费用.突然有一天,L公司的总裁L先生接到气象部门的电话,被告知三天之后将有一场暴雨,于是L先生决定紧急在某些工厂建立一些仓库以免产品被淋坏.由于地形的不同,在不同工厂建立仓库的费用可能是不同的.第i个工厂目前已有成品Pi件,在第i个工厂位置建立仓库的费用是Ci.对

HDU3045 Picnic Cows(斜率优化DP)

Picnic Cows Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 2192    Accepted Submission(s): 675 Problem Description It’s summer vocation now. After tedious milking, cows are tired and wish to t

BZOJ 1096 [ZJOI2007]仓库建设 斜率优化dp

1096: [ZJOI2007]仓库建设 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/problem.php?id=1096 Description L公司有N个工厂,由高到底分布在一座山上.如图所示,工厂1在山顶,工厂N在山脚. 由于这座山处于高原内陆地区(干燥少雨),L公司一般把产品直接堆放在露天,以节省费用.突然有一天,L公司的总裁L先生接到气象部门的电话,被告知三天之后将有一场

HDU 2829 Lawrence (斜率优化DP或四边形不等式优化DP)

题意:给定 n 个数,要你将其分成m + 1组,要求每组数必须是连续的而且要求得到的价值最小.一组数的价值定义为该组内任意两个数乘积之和,如果某组中仅有一个数,那么该组数的价值为0. 析:DP状态方程很容易想出来,dp[i][j] 表示前 j 个数分成 i 组.但是复杂度是三次方的,肯定会超时,就要对其进行优化. 有两种方式,一种是斜率对其进行优化,是一个很简单的斜率优化 dp[i][j] = min{dp[i-1][k] - w[k] + sum[k]*sum[k] - sum[k]*sum[