眼界极窄的ZZ
之前甚至不会单调队列……(好丢人啊)
单调队列优化的常见情景:
这个题学长讲的好像是另外一个思路,但是码的时候不知不觉就偏到另一个思路里去了……改天也打打试试
需要注意的:
>
for(int i=1;i<=n;i++)
{
dp[i][0]=max(dp[i-1][1],dp[i-1][0]);
while(fro<=bac&&Q[fro].id+k+1<=i)fro++;
//ll t=Q[fro].id;
dp[i][1]=Q[fro].v+pre[i];
while(fro<=bac&&dp[i][0]-pre[i]>Q[bac].v)bac--;
Q[++bac].v=dp[i][0]-pre[i];
Q[bac].id=i;
}
这道题和上一道的特征很是不同……
≥
for(int i=1;i<=t;i++)
{
for(int j=0;j<=as[i];j++)dp[i][j]=-j*ap[i];
for(int j=0;j<=mp;j++)dp[i][j]=max(dp[i][j],dp[i-1][j]);//nothing
if(i-w-1<0)continue;
fro=1;bac=0;
for(int j=0;j<=mp;j++)//buy
{
while(fro<=bac&&Q[fro]<j-as[i])fro++;
while(fro<=bac&&dp[i-w-1][j]+ap[i]*j>=dp[i-w-1][Q[bac]]+ap[i]*Q[bac])bac--;
Q[++bac]=j;
if(fro<=bac)dp[i][j]=max(dp[i][j],dp[i-w-1][Q[fro]]+ap[i]*Q[fro]-j*ap[i]);
}
fro=1;bac=0;
for(int j=mp;j>=0;j--)
{
while(fro<=bac&&Q[fro]>j+bs[i])fro++;
while(fro<=bac&&dp[i-w-1][j]+bp[i]*j>=dp[i-w-1][Q[bac]]+bp[i]*Q[bac])bac--;
Q[++bac]=j;
if(fro<=bac)dp[i][j]=max(dp[i][j],dp[i-w-1][Q[fro]]+bp[i]*Q[fro]-j*bp[i]);
}
}
原文:https://www.cnblogs.com/zzzuozhe-gjy/p/12800750.html