bzoj 1855: [Scoi2010]股票交易
Description
Input
Output
Sample Input
2 1 1 1
2 1 1 1
3 2 1 1
4 3 1 1
5 4 1 1
Sample Output
HINT
对于30%的数据,0 < =W 对于50%的数据,0 < =W 对于100%的数据,0 < =W
对于所有的数据,1 < =BPi < =APi < =1000,1 < =ASi,BSi < =MaxP
Source
这个按lst大佬的话来讲好像叫未来收益型Dp?
跟杭二联考的时候做过一个叫分组的题,暴力的做法跟这个题比较像,不再赘述。
首先设f[i][j]表示到了第i天,有j支股票,收益的最大值(这个收益是算了买股票的代价的)
暴力的转移:
复杂度为O(n*MaxP*MaxP),而且这个东西看起来貌似不太好优化。。
把第二和第三个方程转化一下:
然后再整理一下:
发现转移的前面一项是之和k有关的,我们要求的就是前面一项的最大值。
这个我们可以通过把前一项压进单调队列中,维护单调递减的单调队列即可,复杂度为O(n*MaxP)。。
// MADE BY QT666
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<iostream>
#include<cstring>
#include<queue>
using namespace std;
typedef long long ll;
const int N=100050;
int f[3000][3000],ap[N],bp[N],as[N],bs[N],W,T,MaxP,q[N];
int main(){
scanf("%d%d%d",&T,&MaxP,&W);
for(int i=1;i<=T;i++) scanf("%d%d%d%d",&ap[i],&bp[i],&as[i],&bs[i]);
memset(f,-127/3,sizeof(f));int Inf=f[0][0];f[0][0]=0;
for(int i=1;i<=T;i++){
for(int j=0;j<=MaxP;j++) f[i][j]=max(f[i][j],f[i-1][j]);
/*for(int k=max(j-as[i],0);k<=j;k++){
if(f[max(0,i-W-1)][k]==Inf) continue;
f[i][j]=max(f[i][j],f[max(0,i-W-1)][k]-ap[i]*(j-k));
}
for(int k=j;k<=min(j+bs[i],MaxP);k++){
if(f[max(0,i-W-1)][k]==Inf) continue;
f[i][j]=max(f[i][j],f[max(0,i-W-1)][k]+bp[i]*(k-j));
}*/
int head=1,tail=0;q[++tail]=0;
for(int j=0;j<=MaxP;j++){
while(head<=tail&&q[head]<max(j-as[i],0)) head++;
f[i][j]=max(f[i][j],f[max(0,i-W-1)][q[head]]-ap[i]*(j-q[head]));
while(head<=tail&&f[max(0,i-W-1)][j]+ap[i]*j>f[max(0,i-W-1)][q[tail]]+ap[i]*q[tail]) tail--;
q[++tail]=j;
}
head=1,tail=0;q[++tail]=MaxP;
for(int j=MaxP;j>=0;j--){
while(head<=tail&&q[head]>min(MaxP,j+bs[i])) head++;
f[i][j]=max(f[i][j],f[max(0,i-W-1)][q[head]]+bp[i]*(q[head]-j));
while(head<=tail&&f[max(0,i-W-1)][j]+bp[i]*j>f[max(0,i-W-1)][q[tail]]+bp[i]*q[tail]) tail--;
q[++tail]=j;
}
}
int ans=Inf;
for(int j=0;j<=MaxP;j++) ans=max(ans,f[T][j]);
printf("%d\n",ans);
return 0;
}
bzoj 1855: [Scoi2010]股票交易的更多相关文章
- ●BZOJ 1855 [Scoi2010]股票交易
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=1855 题解: DP,单调队列优化.(好久没做 DP题,居然还意外地想出来了) 定义 dp[i ...
- BZOJ 1855 [Scoi2010]股票交易 ——动态规划
DP方程是比较简单的,主要有三种:什么都不做.买入.卖出. 发现买入卖出都是$\Theta (n^3)$但是转移方程都是线性的,而且决策和当前的情况是分开的. 所以可以单调队列优化. 复杂度$\The ...
- 1855: [Scoi2010]股票交易[单调队列优化DP]
1855: [Scoi2010]股票交易 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1083 Solved: 519[Submit][Status] ...
- BZOJ 1855: [Scoi2010]股票交易(DP+单调队列)
1855: [Scoi2010]股票交易 Description 最近lxhgww又迷上了投资股票,通过一段时间的观察和学习,他总结出了股票行情的一些规律. 通过一段时间的观察,lxhgww预测到了未 ...
- 单调队列优化DP || [SCOI2010]股票交易 || BZOJ 1855 || Luogu P2569
题面:P2569 [SCOI2010]股票交易 题解: F[i][j]表示前i天,目前手中有j股的最大收入Case 1:第i天是第一次购买股票F[i][j]=-j*AP[i]; (1<=j< ...
- [BZOJ 1855] 股票交易
Link: BZOJ 1855 传送门 Solution: 比较明显的$dp$模型 令$dp[i][j]$为第$i$天持有$j$支股票时的最大利润 对其购买股票和售出股票分别$dp$,这里以购买为例: ...
- 【BZOJ1855】[Scoi2010]股票交易 DP+单调队列
[BZOJ1855][Scoi2010]股票交易 Description 最近lxhgww又迷上了投资股票,通过一段时间的观察和学习,他总结出了股票行情的一些规律. 通过一段时间的观察,lxhgww预 ...
- 洛谷P2569 [SCOI2010]股票交易
P2569 [SCOI2010]股票交易 题目描述 最近lxhgww又迷上了投资股票,通过一段时间的观察和学习,他总结出了股票行情的一些规律. 通过一段时间的观察,lxhgww预测到了未来T天内某只股 ...
- [luogu] P2569 [SCOI2010]股票交易 (单调队列优化)
P2569 [SCOI2010]股票交易 题目描述 最近 \(\text{lxhgww}\) 又迷上了投资股票,通过一段时间的观察和学习,他总结出了股票行情的一些规律. 通过一段时间的观察,\(\te ...
随机推荐
- J2SE-包装类
目录 1 为什么提供包装类? 2 装箱和拆箱 3 包装类的4个特点 4 包装类类型 正文 1 为什么提供包装类? 1) 由于Java的基本数据类型功能简单,不具备面向对象的特性,实际使用时存在很多的不 ...
- PAT乙级--1003
1003. 我要通过!(20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue "答案正确"是 ...
- 200行Java代码搞定计算器程序
发现了大学时候写的计算器小程序,还有个图形界面,能够图形化展示表达式语法树,哈哈;) 只有200行Java代码,不但能够计算加减乘除,还能够匹配小括号~ 代码点评: 从朴素的界面配色到简单易懂错误提示 ...
- webpack 图片的打包
1. 在img文件夹下随便找一个小一点的图片放进去. 2.修改entry.js require('../css/index.css'); var demo1 = require('../js/demo ...
- NOIP2016提高组初赛(2)四、阅读程序写结果2、
#include <iostream> using namespace std; int main() { ][], b[][]; ]; string tmp; , j = , k = , ...
- zkw模板
水平有限,前缀和的前缀和什么的,rbq 两个操作: 1.区间l到r加上一个数x 2.查询区间[l,r]的区间和 #include<iostream> #include<cstdio& ...
- 查看主机DNSserver
一.Nslookup(name server lookup)( 域名查询):是一个用于查询 Internet 域名信息或诊断DNS server问题的工具.nslookup能够指定查询的类型,能够查到 ...
- WIN7下安装SVNserver端及client搭建协作环境
一.客户场景: 客户现场须要在虚拟机上封闭开发,所以须要搭建一个SVN协作开发环境.客户提供了一台全新的裸机安装的操作系统是WIN7旗舰版64位. 二.SVNserver搭建 1. SVNserver ...
- MySQL Study之--MySQL schema_information数据库
MySQL Study之--MySQL schema_information数据库 information_schema数据库是在mysql的版本号5.0之后产生的,一个虚拟数据库,物理上 ...
- 泛泰A870(高通APQ8064t 600 cpu) Mokee4.4.2(Android4.4) 图赏
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc3lob3N0/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/d ...