这道题 我很蒙.....
首先依照搞单调队列优化dp的一般思路 先写出状态转移方程 在想法子去优化

这个题目中说道w就是这一天要是进行操作就是从前w-1天转移而来因为之前的w天
不允许有操作!就是与这些天的状态无关!
那么每一天更新那一天已经定了那么他对后面要转移的地方的影响就是手里的票了
既然这样就加一维表示
f[i][j]表示到第i天手里有j个票的最大收益这样就无后效性了
f[i][j]=Max(f[i][j],f[last][x]-(j-x)*in[i]);
f[i][j]=Max(f[i][j],f[last][x]+(x-j)*out[i]);
f[i][j]=Max(f[i][j],f[i-1][j]);
三种最大即为所求(第三种是不进行任何操作根据状态数组的增性就用前一个状态来修改就行了)
我很蒙......

#include<cstdio>
#include<queue>
#include<cstring>
using namespace std;
int f[][],in[],out[],inm[],outm[];
int t,mp,w;
deque<int>q;
inline int Max(int x,int y)
{
return x>y?x:y;
}
inline void push(int i,int j,int x)
{
while(!q.empty())
{
int y=q.back();
if(f[i][j]>=f[i][y]-in[x]*(j-y))q.pop_back();
else{ q.push_back(j);break;}
}
if(q.empty())q.push_back(j);
}
inline void pop1(int j)
{
while(q.front()>j&&!q.empty())q.pop_front();
}
inline void push1(int i,int j,int x)
{
while(!q.empty())
{
int y=q.back();
if(f[i][j]>=f[i][y]+out[x]*(y-j))q.pop_back();
else{ q.push_back(j);break;}
}
if(q.empty())q.push_back(j);
}
inline void pop(int j)
{
while(q.front()<j&&!q.empty())q.pop_front();
}
int main()
{ scanf("%d%d%d",&t,&mp,&w);
memset(f,0xaf,sizeof(f));
for(int i=;i<=t;i++)scanf("%d%d%d%d",&in[i],&out[i],&inm[i],&outm[i]);
for(int i=;i<=w+&&i<=t;i++)
{
f[i][]=;
for(int j=;j<=inm[i];j++)
f[i][j]=f[i][j-]-in[i];
for(int j=;j<=mp;j++)
f[i][j]=Max(f[i][j],f[i-][j]);
}
for(int i=w+,last=;i<=t;i++,last++)
{
q.clear();
for(int j=;j<=mp;j++)
{
pop(j-inm[i]);
push(last,j,i);
int x=q.front();
f[i][j]=Max(f[i][j],f[last][x]-(j-x)*in[i]);
}
q.clear();
for(int j=mp;j>=;j--)
{
pop1(j+outm[i]);
push1(last,j,i);
int x=q.front();
f[i][j]=Max(f[i][j],f[last][x]+(x-j)*out[i]);
}
for(int j=;j<=mp;j++)
f[i][j]=Max(f[i][j],f[i-][j]);
}
int ans=;
for(int i=;i<=mp;i++)ans=Max(ans,f[t][i]);
printf("%d",ans);
return ;
}

SCOI 股票交易 单调队列优化dp的更多相关文章

  1. 1855: [Scoi2010]股票交易[单调队列优化DP]

    1855: [Scoi2010]股票交易 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1083  Solved: 519[Submit][Status] ...

  2. bzoj1855: [Scoi2010]股票交易--单调队列优化DP

    单调队列优化DP的模板题 不难列出DP方程: 对于买入的情况 由于dp[i][j]=max{dp[i-w-1][k]+k*Ap[i]-j*Ap[i]} AP[i]*j是固定的,在队列中维护dp[i-w ...

  3. 【bzoj1855】 [Scoi2010]股票交易 单调队列优化DP

    上一篇blog已经讲了单调队列与单调栈的用法,本篇将讲述如何借助单调队列优化dp. 我先丢一道题:bzoj1855 此题不难想出O(n^4)做法,我们用f[i][j]表示第i天手中持有j只股票时,所赚 ...

  4. bzoj1855: [Scoi2010]股票交易 单调队列优化dp ||HDU 3401

    这道题就是典型的单调队列优化dp了 很明显状态转移的方式有三种 1.前一天不买不卖: dp[i][j]=max(dp[i-1][j],dp[i][j]) 2.前i-W-1天买进一些股: dp[i][j ...

  5. LUOGU P2569 [SCOI2010]股票交易(单调队列优化dp)

    传送门 解题思路 不难想一个\(O(n^3)\)的\(dp\),设\(f_{i,j}\)表示第\(i\)天,手上有\(j\)股的最大收益,因为这个\(dp\)具有单调性,所以\(f_i\)可以贪心的直 ...

  6. BZOJ 1855 股票交易 - 单调队列优化dp

    传送门 题目分析: \(f[i][j]\)表示第i天,手中拥有j份股票的最优利润. 如果不买也不卖,那么\[f[i][j] = f[i-1][j]\] 如果买入,那么\[f[i][j] = max\{ ...

  7. BZOJ1855 股票交易 单调队列优化 DP

    描述 某位蒟佬要买股票, 他神奇地能够预测接下来 T 天的 每天的股票购买价格 ap, 股票出售价格 bp, 以及某日购买股票的上限 as,  某日出售股票上限 bs, 并且每次股票交 ♂ 易 ( 购 ...

  8. 股票交易——单调队列优化DP

    题目描述 思路 蒟蒻还是太弱了,,就想到半个方程就GG了,至于什么单调队列就更想不到了. $f[i][j]$表示第$i天有j$张股票的最大收益. 那么有四种选择: 不买股票:$f[i][j]=max( ...

  9. 2018.09.10 bzoj1855: [Scoi2010]股票交易(单调队列优化dp)

    传送门 单调队列优化dp好题. 有一个很明显的状态设置是f[i][j]表示前i天完剩下了j分股票的最优值. 显然f[i][j]可以从f[i-w-1][k]转移过来. 方程很好推啊. 对于j<kj ...

随机推荐

  1. centOS下更新yum源

    CentOS下更新yum源 1.使用如下命令,备份/etc/yum.repos.d/CentOS-Base.repo. cp /etc/yum.repos.d/CentOS-Base.repo /et ...

  2. C语言常用关键语法精华总结

    1.关于typedef的用法总结 2.typedef struct的用法 3.typedef函数指针用法 4.数组指针(数组类型的指针)与指针数组 5.真正明白c语言二级指针 6.C语言for循环(及 ...

  3. 2016年JD工作遇到的问题:1-5,搭建环境和熟悉项目过程中的坑

    1.更新不需要权限的项目A,却提示没有权限. 先从Git上更新项目A的代码,提示没有权限. 然后从Git上更新其它项目B的代码,正常. 再更新项目A的代码,正常了. 奇葩问题! 2.Eclipse中, ...

  4. github简单使用教程(转)

    github是一个基于git的代码托管平台,付费用户可以建私人仓库,我们一般的免费用户只能使用公共仓库,也就是代码要公开.对于一般人来说公共仓库就已经足够了,而且我们也没多少代码来管理,O(∩_∩)O ...

  5. tomcat 异常

    Removing obsolete files from server... Could not clean server of obsolete files: null java.lang.Null ...

  6. UZH slam 两种相机

    1.event camera:http://rpg.ifi.uzh.ch/research_dvs.html 2.SCAMP Vision Sensor:https://personalpages.m ...

  7. php常见安全问题

    XSS攻击原理: XSS又叫CSS (Cross Site Script) ,跨站脚本攻击.它指的是恶意攻击者往Web页面里插入恶意html代码,当用户浏览该页之时,嵌入其中Web里面的html代码会 ...

  8. hibernate延时加载机制

    延迟加载: 延迟加载机制是为了避免一些无谓的性能开销而提出来的,所谓延迟加载就是当在真正需要数据的时候,才真正执行数据加载操作.在Hibernate中提供了对实体对象的延迟加载以及对集合的延迟加载,另 ...

  9. sql between and 边界问题

    1.不同的数据库对 BETWEEN...AND 操作符的处理方式是有差异的.需要自己测试 2.一般情况下.SQL Server中 between and是包括边界值的,not between不包括边界 ...

  10. 【PHP】- session_cache_limiter(private,must-revalidate)是什么意思

    session_cache_limiter(private,must-revalidate)是什么意思 表义一: 指定会话页面所使用的缓冲控制方法: 当session_cache_limiter('p ...