APIO 2010 特别行动队 斜率优化DP
Description
你有一支由 n 名预备役士兵组成的部队,士兵从 1 到 n 编号,要将他们拆分 成若干特别行动队调入战场。出于默契的考虑,同一支特别行动队中队员的编号 应该连续,即为形如 (i, i + 1, ..., i + k)(i,i+1,...,i+k) 的序列。 编号为 i 的士兵的初始战斗力为 xi ,一支特别行动队的初始战斗力 x 为队内 士兵初始战斗力之和,即 x = x_i + x_{i+1} + ... + x_{i+k}x=xi+xi+1+...+xi+k 。
通过长期的观察,你总结出一支特别行动队的初始战斗力 x 将按如下经验公 式修正为 x':x'= ax^2+bx+cx′:x′=ax2+bx+c ,其中 a, b, c 是已知的系数(a < 0)。 作为部队统帅,现在你要为这支部队进行编队,使得所有特别行动队修正后 战斗力之和最大。试求出这个最大和。
例如,你有 4 名士兵, x_1 = 2, x_2 = 2, x_3 = 3, x_4 = 4x1=2,x2=2,x3=3,x4=4 。经验公式中的参数为 a = –1, b = 10, c = –20。此时,最佳方案是将士兵组成 3 个特别行动队:第一队包含士兵 1 和士兵 2,第二队包含士兵 3,第三队包含士兵 4。特别行动队的初始战斗力分 别为 4, 3, 4,修正后的战斗力分别为 4, 1, 4。修正后的战斗力和为 9,没有其它 方案能使修正后的战斗力和更大。
Input
输入由三行组成。第一行包含一个整数 n,表示士兵的总数。第二行包含三 个整数 a, b, c,经验公式中各项的系数。第三行包含 n 个用空格分隔的整数 x_1, x_2, …, x_nx1,x2,…,xn ,分别表示编号为 1, 2, …, n 的士兵的初始战斗力。
Output
输出一个整数,表示所有特别行动队修正后战斗力之和的最大值。
Sample Input
4
-1 10 -20
2 2 3 4
Sample Output
9
HINT
20%的数据中,n ≤ 1000;
50%的数据中,n ≤ 10,000;
100%的数据中,1 ≤ n ≤ 1,000,000,–5 ≤ a ≤ –1,|b| ≤ 10,000,000,|c| ≤ 10,000,000,1 ≤ xi ≤ 100
Solution
看到这道题的时候,我们可以轻易地先写一个暴力DP(f[i]表示前i个队员战斗力修正后的最大值):
f[i]={max(f[j]+calc(sum[i]-sum[j-1]))}
其中calc()即为图中所给的A*x*x+B*x+Cx*x+B*x+C计算函数。
这样n^2暴力DP显然是过不去的,所以我们需要斜率优化。
如果j的决策比k优秀,即:
f[j]+F(c[i]−c[j])>f[k]+F(c[i]−c[k])
又有F(x)=Ax^2+Bx+CF(x)=Ax^2+Bx+C
直接带入得到
f[j]+A(c[i]-c[j])^2+B(c[i]-c[j])+Cf[j]+A(c[i]−c[j])2+B(c[i]−c[j])+C
右边同理
然后两边同时减掉一部分得
f[j]+Ac[j]^2-2Ac[i]c[j]-Bc[j]>f[k]+Ac[k]^2-2Ac[i]c[k]-Bc[k]f[j]+Ac[j]2−2Ac[i]c[j]−Bc[j]>f[k]+Ac[k]2−2Ac[i]c[k]−Bc[k]
然后:
2Ac[i](c[j]-c[k])<(f[j]+Ac[j]^2-Bc[j])-(f[k]+Ac[k]^2-Bc[k])2Ac[i](c[j]−c[k])<(f[j]+Ac[j]2−Bc[j])−(f[k]+Ac[k]2−Bc[k])
然后:
c[i]<(f[j]+Ac[j]^2-Bc[j])-(f[k]+Ac[k]^2-Bc[k])/2A(c[j]-c[k])(c[j]−c[k])
然后就可以进行斜率优化了。
Code
#include <stdio.h>
#include <algorithm>
#define ll long long
using namespace std;
int a,b,c,n,l,r,h,t;
ll sum[],que[],x[],f[],s[];
ll calc(ll x){return a*x*x+b*x+c;}
ll q(ll x){return f[x]+a*sum[x]*sum[x]-b*sum[x];}
double rate(ll j,ll k){return (q(j)-q(k))*1.0/(2.0*a*(sum[j]-sum[k]));}
int main()
{
scanf("%d",&n);
scanf("%d%d%d",&a,&b,&c);
for(int i=;i<=n;i++)
scanf("%d",&x[i]);
for(int i=;i<=n;i++)
sum[i]=sum[i-]+x[i];
for(int i=;i<=n;i++)
f[i]=-1e18;
for(int i=;i<=n;i++)
{
while(l<r&&rate(que[l],que[l+])<=sum[i]*1.0)l++;
f[i]=f[que[l]]+calc(sum[i]-sum[que[l]]);
while(l<r&&rate(que[r-],que[r])>=rate(que[r],i))r--;
que[++r]=i;
}
printf("%lld",f[n]);
}
APIO 2010 特别行动队 斜率优化DP的更多相关文章
- APIO2010 特别行动队 & 斜率优化DP算法笔记
做完此题之后 自己应该算是真正理解了斜率优化DP 根据状态转移方程$f[i]=max(f[j]+ax^2+bx+c),x=sum[i]-sum[j]$ 可以变形为 $f[i]=max((a*sum[j ...
- [APIO2010]特别行动队 --- 斜率优化DP
[APIO2010]特别行动队 题面很直白,就不放了. 太套路了,做起来没点感觉了. \(dp(i)=dp(j)+a*(s(i)-s(j))^{2}+b*(s(i)-s(j))+c\) 直接推出一个斜 ...
- bzoj1911[Apio2010]特别行动队 斜率优化dp
1911: [Apio2010]特别行动队 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 5057 Solved: 2492[Submit][Statu ...
- BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]
1911: [Apio2010]特别行动队 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 4142 Solved: 1964[Submit][Statu ...
- BZOJ 1911 特别行动队(斜率优化DP)
应该可以看出这是个很normal的斜率优化式子.推出公式搞一搞即可. # include <cstdio> # include <cstring> # include < ...
- luogu3628 特别行动队 (斜率优化dp)
推出来式子以后斜率优化水过去就完事了 #include<cstdio> #include<cstring> #include<algorithm> #include ...
- bzoj1911 [Apio2010]特别行动队——斜率优化DP
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1911 相当明显的斜率优化,很好做: 注意slp里面要有(double),以免出现精度问题. ...
- 【BZOJ1911】[Apio2010]特别行动队 斜率优化DP
想了好久啊....——黑字为第一次更新.——这里是第二次更新,维护上下凸包据题而论,第一种方法是化式子的方法,需要好的化式子的方法,第二种是偏向几何,十分好想,纯正的维护凸包的方法,推荐. 用了我感觉 ...
- bzoj 1911: [Apio2010]特别行动队 -- 斜率优化
1911: [Apio2010]特别行动队 Time Limit: 4 Sec Memory Limit: 64 MB Description Input Output Sample Input 4 ...
随机推荐
- list.Except()
差集 List<string> list = new List<string>() { ", ", ", }; List<string> ...
- 图论介绍(Graph Theory)
1 图论概述 1.1 发展历史 第一阶段: 1736:欧拉发表首篇关于图论的文章,研究了哥尼斯堡七桥问题,被称为图论之父 1750:提出了拓扑学的第一个定理,多面体欧拉公式:V-E+F=2 第二阶段( ...
- CSS相关(2)
特效: 2D: 平移:可以为负值,单位px transform:translateX(200px) translateY(200px); 简写:transform ...
- java并发(二):初探syncronized
参考博客 Java多线程系列--"基础篇"04之 synchronized关键字 synchronized基本规则 第一条 当线程访问A对象的synchronized方法和同步块的 ...
- MongoDB in 数量限制
1.查询语句本身其实是一个document, 最大为16MB(3.4,4.0 的限制,官方文档)2.查询语句本身,也就是{ '' : { '$in' : [] }}, 大小为 22字节3.每增加一个字 ...
- SystemVerilog基本语法总结(上)
SystemVerilog基本语法总结(上) 在总结SV的语法之前,先分享一些关于SV的笔试题目,这样更显得具有针对性的总结. a. 验证中,代码覆盖率是指(衡量哪些设计代码在激活触发,而哪一些则一直 ...
- 【android官方文档】与其他App交互
发送用户到另外一个App YOU SHOULD ALSO READ 内容分享 One of Android's most important features is an app's ability ...
- Eclipse - 常见问题 - Refresh
有时候项目代码正确但运行后出现异常,是因为eclipse没有刷新 (如jar包添加了但没用),比较脑慢. 解决方法: clean缓存,或者要多点几次Refresh,或者重启 eclipse.
- Python 100 Days
Day 1 python的缺点 执行效率稍低,因此计算密集型任务可以由C/C++编写. 在开发时可以选择的框架太多(如Web框架就有100多个),有选择的地方就有错误. python解释器 官方的Py ...
- django 自定义模版过滤器
自定义的模版过滤器必须要放在app中,并且该app必须在INSTALLED_APPS中进行安装.然后再在这个app下面创建一个python包叫做templatetags(这个名字是固定的,不能随意更改 ...