【单调队列优化dp】HDU 3401 Trade
http://acm.hdu.edu.cn/showproblem.php?pid=3401
【题意】
- 知道之后n天的股票买卖价格(api,bpi),以及每天股票买卖数量上限(asi,bsi),问他最多能赚多少钱。开始时有无限本金,要求任两次交易需要间隔W天以上,即第i天交易,第i+w+1天才能再交易。同时他任意时刻最多只能拥有maxp的股票
【思路】
- dp[i][j]表示第i天拥有j支股票的最大收益,有三种转移方案:
- dp[i][j]=max(dp[i][j],dp[i-1][j])表示第i天不买也不卖,由前一天转移而来
- dp[i][j]=max(dp[i][j],dp[i-w-1][k]-(j-k)*ap[i])表示第i天买股票,有第i-w-1天转移而来
- dp[i][j]=max(dp[i][j],dp[i-w-1][k]+(k-j)*bp[i])表示第i天卖股票,有第i-w-1天转移而来
- 注意只需计算由i-w-1天转移而来,因为i-w-1天前的最优值已经通过不买不卖转移到了i-w-1天,即dp[i][j],j固定是随i单调递增的
- 现在dp的复杂度是n^3,怎样降低复杂度?
- 分析买股票的情况,dp[i][j]=max(dp[i-w-1][k]+k*ap[i])-j*ap[j],类似a[i]=max(b[k])+c[i],可以用单调队列优化
- 我理解的是,状态数为2D,转移为1D,然后又有单调性,可以固定一维状态,把转移均摊到另一维,相当于转移是O(1)的,所以单调队列可以把dp降一维
- a[i]=max(b[k]),若k<=j是从前往后递推,若k>=j是从后往前递推
【AC】
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=2e3+;
const int inf=0x3f3f3f3f;
int ap[maxn],bp[maxn],as[maxn],bs[maxn];
int n,maxp,w;
int dp[maxn][maxn];
struct node
{
int x;
int num;
}q[maxn];
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
memset(dp,-inf,sizeof(dp));//求最大值,所以初始化为无穷小
scanf("%d%d%d",&n,&maxp,&w);
for(int i=;i<=n;i++) scanf("%d%d%d%d",&ap[i],&bp[i],&as[i],&bs[i]);
for(int i=;i<=n;i++) dp[i][]=;//拥有股票为0的最大收益当前是0
//前w+1天和[w+2,n]要分开算
//前w+1天只有两种情况:1.每天都不买不卖 2.其中一天买了股票 不能卖股票,而且最多只有一天能交易
for(int i=;i<=w+;i++)
{
for(int j=;j<=as[i];j++)
{
dp[i][j]=-j*ap[i];//可以选择在当天买
}
}
for(int j=;j<=maxp;j++)
{
for(int i=;i<=w+;i++)
{
dp[i][j]=max(dp[i][j],dp[i-][j]);//也可以选择由前一天转移而来
}
}
for(int i=w+;i<=n;i++)
{
int head=,tail=;
for(int j=;j<=maxp;j++)
{
dp[i][j]=max(dp[i][j],dp[i-][j]);//不买也不卖
//dp[i][j]=max(dp[i-w-1][k]+k*ap[i])-j*ap[i],其中k<=j
while(head<=tail&&q[tail].x<=dp[i-w-][j]+j*ap[i]) tail--;
q[++tail].x=dp[i-w-][j]+j*ap[i];q[tail].num=j;
while(q[head].num+as[i]<j) head++;
dp[i][j]=max(dp[i][j],q[head].x-j*ap[i]);
}
//dp[i][j]=max(dp[i-w-1][k]+k*bp[i])-j*bp[i],其中k>=j
head=,tail=;
for(int j=maxp;j>=;j--)
{
while(head<=tail&&q[tail].x<=dp[i-w-][j]+j*bp[i]) tail--;
q[++tail].x=dp[i-w-][j]+j*bp[i];q[tail].num=j;
while(q[head].num>bs[i]+j) head++;
dp[i][j]=max(dp[i][j],q[head].x-j*bp[i]);
}
}
int ans=;
for(int i=;i<=maxp;i++)
{
ans=max(ans,dp[n][i]);
}
printf("%d\n",ans);
} return ;
}
单调队列优化dp
【单调队列优化dp】HDU 3401 Trade的更多相关文章
- 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 ...
- 单调队列优化DP,多重背包
单调队列优化DP:http://www.cnblogs.com/ka200812/archive/2012/07/11/2585950.html 单调队列优化多重背包:http://blog.csdn ...
- 单调队列优化DP——习题收集
前言 感觉可以用单调队列优化dp的模型还是挺活的,开个随笔记录一些遇到的比较有代表性的模型,断续更新.主要做一个收集整理总结工作. 记录 0x01 POJ - 1821 Fence,比较适合入门的题, ...
- Parade(单调队列优化dp)
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=2490 Parade Time Limit: 4000/2000 MS (Java/Others) ...
- 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 ...
- hdu3401:单调队列优化dp
第一个单调队列优化dp 写了半天,最后初始化搞错了还一直wa.. 题目大意: 炒股,总共 t 天,每天可以买入na[i]股,卖出nb[i]股,价钱分别为pa[i]和pb[i],最大同时拥有p股 且一次 ...
- BZOJ_3831_[Poi2014]Little Bird_单调队列优化DP
BZOJ_3831_[Poi2014]Little Bird_单调队列优化DP Description 有一排n棵树,第i棵树的高度是Di. MHY要从第一棵树到第n棵树去找他的妹子玩. 如果MHY在 ...
- 【单调队列优化dp】 分组
[单调队列优化dp] 分组 >>>>题目 [题目] 给定一行n个非负整数,现在你可以选择其中若干个数,但不能有连续k个数被选择.你的任务是使得选出的数字的和最大 [输入格式] ...
随机推荐
- restful十项规范
1.协议 API与用户的通信都是通过HTTPS协议进行的 2.域名 应尽量将API部署在专有域名下:https://api.example.com 如果确定API很简单,不会有什么扩展,则可以放在主域 ...
- COGS 1144. [尼伯龙根之歌] 精灵魔法
★ 输入文件:alfheim.in 输出文件:alfheim.out 简单对比时间限制:1 s 内存限制:128 MB [题目背景] 『谜题在丛林中散发芳香绿叶上露珠跳跃着歌唱火焰在隐 ...
- js 分组数组
思路: 1.先将数组按照一定规则排序: 2.再拆分数组到Map中,按Key分类: 3.再从Map中遍历取出要显示的内容: sortBroadList: function (broadcastList) ...
- (一)SpringMVC之警告: No mapping found for HTTP request with URI
这个警告往往是因为url路径不正确. 所以从三个地方下手: 1.springmvc-config.xml中的配置handle,看看是不是因为handle没有配置导致的. 2.如果是使用注解的方式的话, ...
- (十四)maven之启动tomcat
前言:在网上找了好几种方法启动web项目.比较好用的是:①在Project Facets勾上Dynamic....,但是这个方法会改变项目结构(把WebContent的东西都弄出来了):②使用jett ...
- org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'requestMappingHandlerMapping' defined in class path resource
spring boot web项目运行时提示如下错误 org.springframework.beans.factory.BeanCreationException: Error creating b ...
- Invalid bound statement (not found): com.ros.dao.LogMapper.insert
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.ros.dao.LogMapp ...
- leetcode_1049. Last Stone Weight II_[DP]
1049. Last Stone Weight II https://leetcode.com/problems/last-stone-weight-ii/ 题意:从一堆石头里任选两个石头s1,s2, ...
- Centos7 安装python3.5.3
使用root用户安装:切换到root用户 su 回车,然后输入密码,切换到root用户. 新建一个脚本,如installPython.sh #!/bin/bash yum -y install zli ...
- iview 验证 trigger: 'blur,change', 同时加两个,省的每次还想input 还是 select
iview 验证 trigger: 'blur,change', 同时加两个,省的每次还想input 还是 select dataRuleValidate: { name: [{ required: ...