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 ...
随机推荐
- 75、django之ORM补充
本篇导航: QuerySet 中介模型 查询优化 一.QuerySet 1.可切片 使用Python 的切片语法来限制查询集记录的数目 .它等同于SQL 的LIMIT 和OFFSET 子句. > ...
- Java数据结构和算法(六)——前缀、中缀、后缀表达式
前面我们介绍了三种数据结构,第一种数组主要用作数据存储,但是后面的两种栈和队列我们说主要作为程序功能实现的辅助工具,其中在介绍栈时我们知道栈可以用来做单词逆序,匹配关键字符等等,那它还有别的什么功能吗 ...
- C# 使用Task实现任务超时,多任务一起执行
简介:充分使用Task的异步功能代码实现:1.实现了任务超时 退出任务 2.多个任务一起执行 /// <summary> ///做事 需要 ms秒 才能完成 / ...
- 51Nod--1051最大子矩阵和(DP入门)
分析: 我们已经解决了一维的问题(基础篇中的最大子段和问题),现在变成二维了,我们看看能不能把这个问题转化为一维的问题.最后子矩阵一定是在某两行之间的.假设我们认为子矩阵在第i行和第j列之间,我们如何 ...
- c++ 中 pair 的 使用方法
原转载地址:点击打开链接 pair的类型: pair 是 一种模版类型.每个pair 可以存储两个值.这两种值无限制.也可以将自己写的struct的对象放进去.. pair<string,int ...
- 白话图解HTTPS原理
[前言]最近看过几篇文章,内容是关于"全民HTTPS"的.为什么HTTPS,突然会受到如此多业内人士的青睐呢?HTTPS究竟是什么呢?它与HTTP又有怎样的区别呢? 带着这 ...
- UWP 邮件反馈
在我们构建App的时候,一个很人性化的设计就是增加邮件反馈渠道,就是让用户直接发邮件给你反馈. 当然,你也可以用系统自带的"反馈中心"(超级无敌难用,还经常打不开),或者使用商店的 ...
- scapy安装及SCTP包分析
关于Scapy scapy是一个强大的交互式数据包处理程序(使用python编写).它能够伪造或者解码大量的网络协议数据包,能够发送.捕捉.匹配请求和回复包等.它可以很容易地处理一些典型操作,比如端口 ...
- Jsoup(一)Jsoup详解(官方)
一.Jsoup概述 1.1.简介 jsoup 是一款Java 的HTML解析器,可直接解析某个URL地址.HTML文本内容.它提供了一套非常省力的API, 可通过DOM,CSS以及类似于jQu ...
- java学习总结篇一--写在正式成为码农一年后
一直想写一写工作了一年多的总结与感悟,今天正好有时间,也有这个兴致,随手总结一下这一年来学习及工作的情况. 大学时很无奈地被选择了计算机专业,本人对计算机,不讨厌,也算不上多喜欢.只是当惯了好学生,好 ...