bzoj1911: [Apio2010]特別行動隊(斜率優化+Dp)
題目傳送門
好開心又獨立做了一道斜率優化原來斜率優化也不是辣麼難嘛。。
解法:
這道題Dp方程還是蠻好想的。
s[i]表示1到i的和。
f[i]=min(f[i],f[j]+a*(s[i]-s[j])^2+b*(s[i]-s[j])+c)
斜率優化。。
設j>k且j對於i更優。
f[j]+a*(s[i]-s[j])^2+b*(s[i]-s[j])+c<f[k]+a*(s[i]-s[k])^2+b*(s[i]-s[k])+c
化簡:
a*s[i]^2,b*s[i],c兩邊都可以約(其實我是寫不下才不寫的)
f[j]-2*a*s[i]*s[j]+a*s[j]^2-b*s[j]<f[k]-2*a*s[i]*s[k]+a*s[k]^2-b*s[k]
(f[j]+a*s[j]^2-b*s[j])-(f[k]+a*s[k]^2-b*s[k])<2*a*s[i]*s[j]-2*a*s[i]*s[k]
(f[j]+a*s[j]^2-b*s[j])-(f[k]+a*s[k]^2-b*s[k])/(2*a*(s[j]-s[k]))<s[i]
打方程累死我。。
然後單調佇列維護一下下凸包就好。
程式碼實現:
#include<cmath>
#include<queue>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
ll s[1100000];
ll a,b,c;
ll f[1100000];
double slop(int j,int k) { //我打程式碼的時候反過來了。。
return double((f[k]+a*s[k]*s[k]-b*s[k])-(f[j]+a*s[j]*s[j]-b*s[j]))/(2*a*(s[k]-s[j]));
}
int list[1100000],head,tail;
int main() {
int n;scanf("%d",&n);
scanf("%lld%lld%lld",&a,&b,&c);
s[0]=0;
for(int i=1;i<=n;i++) {
ll x;scanf("%lld",&x);s[i]=s[i-1]+x;
}
head=1;tail=1;list[1]=0;
for(int i=1;i<=n;i++) {
while(head<tail&&slop(list[head],list[head+1])<s[i])
head++;
int t=list[head];
f[i]=f[t]+a*(s[i]-s[t])*(s[i]-s[t])+b*(s[i]-s[t])+c;
while(head<tail&&slop(list[tail-1],list[tail])>slop(list[tail],i))
tail--;
list[++tail]=i;
}
printf("%lld\n",f[n]);
return 0;
}
相關文章
- 【DP】斜率優化初步優化
- 斜率優化DP總結優化
- 斜率優化(凸包優化)DP問題acm優化ACM
- 斜率最佳化 DP
- 斜率最佳化dp
- poj 1180 dp的斜率優化優化
- hdu 3507 斜率優化DP入門題優化
- 斜率優化動態規劃優化動態規劃
- 淺談斜率最佳化DP
- bzoj3156: 防禦準備(斜率優化+Dp)優化
- 洛谷P2365/5785 任務安排 題解 斜率優化DP優化
- BZOJ 1597 [Usaco2008 Mar]土地購買:斜率優化dp優化
- 斜率優化學習筆記優化筆記
- BZOJ 1010 [HNOI2008]玩具裝箱toy:斜率優化dp優化
- BZOJ 1096 [ZJOI2007]倉庫建設:斜率優化dp優化
- Win7特別功能:優化篇Win7優化
- BZOJ 1492 [NOI2007]貨幣兌換Cash:斜率優化dp + cdq分治優化
- bzoj1597: [Usaco2008 Mar]土地購買(斜率優化+Dp+單調佇列)優化佇列
- 洛谷P4027 [NOI2007]貨幣兌換(dp 斜率優化 cdq 二分)優化
- 斜率最佳化(李超樹)
- 斜率最佳化筆記筆記
- HDU 4427 Math Magic【dp+優化+滾動陣列】【好題】優化陣列
- 【dp+離散化+線段樹優化】Paint優化AI
- 物體識別互動系統的特點及優勢
- 四邊形不等式優化DP優化
- ?️Hanjst/漢吉斯特更新加JavaScript執行時優化等JSJavaScript優化
- 中國銀行的特別事件事件
- RWP團隊談SQL優化SQL優化
- CF940E Cashback 線段樹優化DP優化
- 用多項式的逆優化dp總結優化
- [DP] DP最佳化總結
- 淘特 Flutter 流式場景的深度優化Flutter優化
- UVA 674 01揹包 2進位制優化 DP優化
- 運籌優化(十六)--排隊論基礎及其最優化求解優化
- 動態 DP
- Android 效能優化 ---- 啟動優化Android優化
- 如何進行 Linux 啟動時間優化Linux優化
- POJ3744 Scout YYF I (概率DP + 矩陣優化)矩陣優化