SCOI 股票交易 单调队列优化dp
这道题 我很蒙.....
首先依照搞单调队列优化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的更多相关文章
- 1855: [Scoi2010]股票交易[单调队列优化DP]
1855: [Scoi2010]股票交易 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1083 Solved: 519[Submit][Status] ...
- 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 ...
- 【bzoj1855】 [Scoi2010]股票交易 单调队列优化DP
上一篇blog已经讲了单调队列与单调栈的用法,本篇将讲述如何借助单调队列优化dp. 我先丢一道题:bzoj1855 此题不难想出O(n^4)做法,我们用f[i][j]表示第i天手中持有j只股票时,所赚 ...
- 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 ...
- LUOGU P2569 [SCOI2010]股票交易(单调队列优化dp)
传送门 解题思路 不难想一个\(O(n^3)\)的\(dp\),设\(f_{i,j}\)表示第\(i\)天,手上有\(j\)股的最大收益,因为这个\(dp\)具有单调性,所以\(f_i\)可以贪心的直 ...
- BZOJ 1855 股票交易 - 单调队列优化dp
传送门 题目分析: \(f[i][j]\)表示第i天,手中拥有j份股票的最优利润. 如果不买也不卖,那么\[f[i][j] = f[i-1][j]\] 如果买入,那么\[f[i][j] = max\{ ...
- BZOJ1855 股票交易 单调队列优化 DP
描述 某位蒟佬要买股票, 他神奇地能够预测接下来 T 天的 每天的股票购买价格 ap, 股票出售价格 bp, 以及某日购买股票的上限 as, 某日出售股票上限 bs, 并且每次股票交 ♂ 易 ( 购 ...
- 股票交易——单调队列优化DP
题目描述 思路 蒟蒻还是太弱了,,就想到半个方程就GG了,至于什么单调队列就更想不到了. $f[i][j]$表示第$i天有j$张股票的最大收益. 那么有四种选择: 不买股票:$f[i][j]=max( ...
- 2018.09.10 bzoj1855: [Scoi2010]股票交易(单调队列优化dp)
传送门 单调队列优化dp好题. 有一个很明显的状态设置是f[i][j]表示前i天完剩下了j分股票的最优值. 显然f[i][j]可以从f[i-w-1][k]转移过来. 方程很好推啊. 对于j<kj ...
随机推荐
- python学习——装饰器函数
一.装饰器函数的作用是什么 答:装饰器函数是在不修改原函数及其调用方式的情况下对原函数功能进行扩展 对于搞python开发的人来说,函数占据了至关重要的地位.都说学好函数你就可以去找工作了,好了,假如 ...
- PHP json_decode返回null解析失败原因
在PHP5.4之前 json_decode函数有两个参数json_decode有两个参数,第一个是待解析的字符串,第二个是是否解析为Array json_decode要求的字符串比较严格:(1)使用U ...
- Linux mysql启动与关闭
service mysql stop service mysqld start
- SET UPDATE TASK LOCAL (ローカル更新 )
ローカル更新では.更新プログラムは要求を処理したのと同じワークプロセスによって実行されます.ダイアログユーザは更新が終了するまで待ってから追加データを入力しなければなりません.データベースへのアクセス ...
- java性能测试工具 jprofiler
1.下载地址 官方网址:http://www.ej-technologies.com/products/jprofiler/overview.html 2.Eclipse集成 该文(http://ji ...
- Android面试收集录 电话、短信和联系人、多媒体技术
1.请写出调用系统拨号界面? Intent intent=new Intent(Intent.ACTION_DIAL,Uri.pase("tel:12345678910")); s ...
- 【转】moodle中年级、班级、小组研讨
Moodle平台支持年级.班级.小组功能,提供了方便易用的分组工具.小组支持公开和封闭属性,配合教学功能模块,教师可以组织小组为单位的教学活动. 在Moodle中,年级.班级.小组主要是通过群组(co ...
- 7.Mongodb复制(副本集)
1.复制 什么是复制 复制提供了数据的冗余备份,并在多个服务器上存储数据副本,提高了数据的可用性,并可以保证数据的安全性 复制还允许从硬件故障和服务中断中恢复数据 为什么要复制 数据备份 数据灾难恢复 ...
- 网易云terraform实践
此文已由作者王慎为授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 一.terraform介绍 随着应用上云的常态化,资源栈动态管理的需求对用户也变得更加急切.资源编排(Res ...
- Android各版本代号、版本号、API/NDK级别、发布时间
代号 版本号 API/NDK级别 发布时间 牛轧糖 Nougat 7.1.2 API level 25 2017-2 7.1.1 2016-10 7.0 API level 24 2016-05 棉花 ...