【BZOJ1205】[HNOI2005]星际贸易(动态规划)
【BZOJ1205】[HNOI2005]星际贸易(动态规划)
题面
题解
第一问就是一个裸\(dp\),因为什么都不用考虑。。。
所以设\(f[i][j]\)表示当前停靠在第\(i\)个星球,已经卖了\(j\)吨货的最大收益。
反正只需要最大收益,在每个地方都停下去维护就好了。无解什么的直接判相邻两个位置就好了吧。
因为保证了方案唯一,所以通过\(dp\)还原就知道哪些地方是必须去卖东西的了。
那么现在考虑的只有燃料和收益两个东西了,设\(f[i][j]\)表示当前在第\(i\)个星球,剩余燃料为\(j\)的最小花费的代价,那么转移就是买燃料和维修,而转移过来的位置是在\(i\)之前合法的一个位置,发现这个东西可以单调队列优化一下。似乎就没有了。
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector>
using namespace std;
#define ll long long
#define MAX 2020
inline int read()
{
int x=0;bool t=false;char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=true,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return t?-x:x;
}
int n,m,R,L,A[MAX],B[MAX],S[MAX],P[MAX],F[MAX];
int f[MAX][MAX<<1];
int Q[MAX<<1][MAX],h[MAX<<1],t[MAX<<1];
bool vis[MAX];
int main()
{
n=read();m=read();R=read();L=read();R=min(R,2*n);
for(int i=1;i<=n;++i)A[i]=read(),B[i]=read(),S[i]=read(),P[i]=read(),F[i]=read();
for(int i=1;i<=n;++i)if(S[i]-S[i-1]>L){puts("Poor Coke!");return 0;}
memset(f,-63,sizeof(f));f[0][0]=0;
for(int i=1;i<=n;++i)
for(int j=0;j<=m;++j)
{
if(j>=A[i])f[i][j]=max(f[i-1][j],f[i-1][j-A[i]]+B[i]);
f[i][j]=max(f[i][j],f[i-1][j]);
}
int ans1=0;for(int j=1;j<=m;++j)if(f[n][ans1]<f[n][j])ans1=j;int val=f[n][ans1];
for(int i=n,nw=ans1;i;--i)if(f[i][nw]!=f[i-1][nw])vis[i]=true,nw-=A[i];
memset(f,63,sizeof(f));
f[0][R]=0;Q[R][t[R]++]=0;
for(int i=1;i<=n;++i)
for(int j=0;j<=R;++j)
{
if(P[i]&&j)f[i][j]=min(f[i][j],f[i][j-1]+P[i]);
if(h[j+2]<t[j+2])f[i][j]=min(f[i][j],f[Q[j+2][h[j+2]]][j+2]+F[i]);
if(vis[i])h[j]=t[j]=0;
while(h[j]<t[j]&&f[Q[j][t[j]-1]][j]>=f[i][j])--t[j];
Q[j][t[j]++]=i;
while(h[j]<t[j]&&S[i+1]-S[Q[j][h[j]]]>L)++h[j];
}
int ans2=0;for(int i=1;i<=R;++i)if(f[n][i]<f[n][ans2])ans2=i;
if(f[n][ans2]>1e9)puts("Poor Coke!");
else printf("%d %d\n",val,val-f[n][ans2]);
return 0;
}
【BZOJ1205】[HNOI2005]星际贸易(动态规划)的更多相关文章
- bzoj1205: [HNOI2005]星际贸易
题目链接 bzoj1205: [HNOI2005]星际贸易 题解 辣鸡题面,毁我青春 辣鸡题面,毁我青 辣鸡题面,毁我 辣鸡题面,毁 第一问,背包dp 第二问 问题转化为在一个序列上经过好多点走到终点 ...
- 洛谷 P2317 [HNOI2005]星际贸易 解题报告
P2317 [HNOI2005]星际贸易 题目描述 输入输出格式 输入格式: 输出格式: 如果可以找到这样的方案,那么输出文件output.txt中包含两个整数X和Y.X表示贸易额,Y表示净利润并且两 ...
- [HNOI2005]星际贸易
https://www.zybuluo.com/ysner/note/1309789 题面 要素太多,还是自己看吧 解析 如果要求贸易额最大,就相当于: 有\(n\)个物品(星球),每个物品价值为\( ...
- [luogu2317 HNOI2005] 星际贸易 (dp)
传送门 Solution 两个dp分开处理, 第一问什么都不考虑直接dp 第二问还有些疑惑,姑且先留坑 Code //By Menteur_Hxy #include <cstdio> #i ...
- 【简●解】[HNOI2005]星际贸易
[大意] 太多了,懒得打,贴\(LG\)的图了... [分析] 开始拿到这道题有点慌:怎么限制条件这么多,再读读题. 注意一个东西,就是贸易额与费用是独立分开的,并且题目保证只有一种方案获得最大贸易额 ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- cyyz: Day 4 网络流整理
Day 4 网络流的理论性知识(算了..我自己都看不下去,还是整理些例题以后复习用吧qaq): 一.PPT(主要内容) 二.搜自度娘 定义: 年,L.R. 福特和 D.R. 富尔克森等人给出了解决 ...
- 51nod1773 A国的贸易
基准时间限制:2 秒 空间限制:524288 KB 分值: 40 A国是一个神奇的国家. 这个国家有 2n 个城市,每个城市都有一个独一无二的编号 ,编号范围为0~2n-1. A国的神奇体现在,他们 ...
- [SinGuLaRiTy] 动态规划题目复习
[SinGuLaRiTy-1026] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. [UVA 1025] A Spy in the Metr ...
随机推荐
- 从0开始学golang--2.1--如何去爬园子的数据
20天过去了,才开始写...主要还是因为自己懒吧.之前一边上班一边也有挤时间练习golang,可是写博客却老是不能行动,跑步也没跑了.突然的就懈怠了快一个月.可能也和开始玩the elder scro ...
- R语言的数据输入
既然了解了R语言的基本数据类型,那么如何将庞大的数据送入R语言进行处理呢?送入的数据又是如何在R语言中进行存储的呢?处理这些数据的方法又有那些呢?下面我们一起来探讨一下. 首先,数据输入最直接最直观的 ...
- 20155210 Exp9 Web安全基础实践
Exp9 Web安全基础实践 实验过程 开启webgoat 输入java -jar webgoat-container-7.1-exec.jar,来运行webgoat 在浏览器输入localhost: ...
- spring配置多个事务管理器
<tx:annotation-driven/> <bean id="transactionManager1" class="org.springfram ...
- 学习JAVA第一章的心得
我抱着万分期待的心情开始了我第一天的JAVA学习课程,其实在第一开始的时候我对计算机行业便有很高地兴趣了.这主要归功于我真的从很小开始就就接触了电脑.进入学校以来,我就很期待老师会怎样教我们,会怎样带 ...
- REST-framework快速构建API--频率
前面已经了解了API的认证和授权.认证,是对资源访问者的第一道门,必须有钥匙,你才能进来拿我的资源:授权,是对资源访问者的第二道门,虽然你进来了,但是你可以拿走什么资源,还是我说了算,就是授权. 当然 ...
- Flutter - 快速创建Stateless和Stateful组件
1. 快速创建Stateless组件 输入stle,回车 class extends StatelessWidget { @override Widget build(BuildContext con ...
- swift学习:第一个swift ui程序
最近swift有点火,赶紧跟上学习.于是,个人第一个swift程序诞生了... 新建项目
- docker之搭建私有仓库
一.私有仓库 1.防止网络原因:下载慢,访问不到的情况,需要在内网搭建一个私有仓库. 二.仓库镜像下载 [root@node03 ~]# docker pull registry 三.创建私有仓库容器 ...
- 【文章存档】如何通过 GitLab 进行持续部署
好久没写博客了,这几天存档一下新文章. 链接 https://docs.azure.cn/zh-cn/articles/azure-operations-guide/app-service-web/a ...