【BZOJ1205】[HNOI2005]星际贸易(动态规划)

题面

BZOJ

洛谷

题解

第一问就是一个裸\(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]星际贸易(动态规划)的更多相关文章

  1. bzoj1205: [HNOI2005]星际贸易

    题目链接 bzoj1205: [HNOI2005]星际贸易 题解 辣鸡题面,毁我青春 辣鸡题面,毁我青 辣鸡题面,毁我 辣鸡题面,毁 第一问,背包dp 第二问 问题转化为在一个序列上经过好多点走到终点 ...

  2. 洛谷 P2317 [HNOI2005]星际贸易 解题报告

    P2317 [HNOI2005]星际贸易 题目描述 输入输出格式 输入格式: 输出格式: 如果可以找到这样的方案,那么输出文件output.txt中包含两个整数X和Y.X表示贸易额,Y表示净利润并且两 ...

  3. [HNOI2005]星际贸易

    https://www.zybuluo.com/ysner/note/1309789 题面 要素太多,还是自己看吧 解析 如果要求贸易额最大,就相当于: 有\(n\)个物品(星球),每个物品价值为\( ...

  4. [luogu2317 HNOI2005] 星际贸易 (dp)

    传送门 Solution 两个dp分开处理, 第一问什么都不考虑直接dp 第二问还有些疑惑,姑且先留坑 Code //By Menteur_Hxy #include <cstdio> #i ...

  5. 【简●解】[HNOI2005]星际贸易

    [大意] 太多了,懒得打,贴\(LG\)的图了... [分析] 开始拿到这道题有点慌:怎么限制条件这么多,再读读题. 注意一个东西,就是贸易额与费用是独立分开的,并且题目保证只有一种方案获得最大贸易额 ...

  6. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  7. cyyz: Day 4 网络流整理

    Day 4 网络流的理论性知识(算了..我自己都看不下去,还是整理些例题以后复习用吧qaq): 一.PPT(主要内容)   二.搜自度娘 定义: 年,L.R. 福特和 D.R. 富尔克森等人给出了解决 ...

  8. 51nod1773 A国的贸易

    基准时间限制:2 秒 空间限制:524288 KB 分值: 40  A国是一个神奇的国家. 这个国家有 2n 个城市,每个城市都有一个独一无二的编号 ,编号范围为0~2n-1. A国的神奇体现在,他们 ...

  9. [SinGuLaRiTy] 动态规划题目复习

    [SinGuLaRiTy-1026] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. [UVA 1025] A Spy in the Metr ...

随机推荐

  1. Hadoop Version History and Feature

    Versions and Features Hadoop has seen significant interest over the past few years. This has led to ...

  2. SqlServer执行大的数据库脚本出错解决方法

    如果执行线上项目拷下来sqlserver的.sql的数据库脚本文件,如果文件较大时,那么就会报错内存不足之类的. 这时可以在命令提示符使用命令来执行脚本文件.切记,执行前先改一下数据库存放位置! 命令 ...

  3. 跟我学Android NDK开发(一)

    Android NDK 开发跟其它开发一样,首先需要配置好开发环境,本文以 Ubuntu系统为例介绍如何进行 Android NDK 开发环境的配置. 1. 简介 什么是 Android NDK 呢? ...

  4. 2017-2018-2 20155224『网络对抗技术』Exp6:信息搜集与漏洞扫描

    实践内容 各种搜索技巧的应用 DNS IP注册信息的查询 基本的扫描技术:主机发现.端口扫描.OS及服务版本探测.具体服务的查点 漏洞扫描:会扫,会看报告,会查漏洞说明,会修补漏洞 基本问题回答 哪些 ...

  5. SVD(奇异值分解)Python实现

    注:在<SVD(奇异值分解)小结 >中分享了SVD原理,但其中只是利用了numpy.linalg.svd函数应用了它,并没有提到如何自己编写代码实现它,在这里,我再分享一下如何自已写一个S ...

  6. libgdx学习记录24——九宫格NinePatch

    NinePatch用于图片纹理拉伸显示.当图片拉伸时,4个角不会拉伸,而只有中间的部分会拉伸,适合做圆角矩形类的Button. 简单示例: package com.fxb.newtest; impor ...

  7. springboot项目生成jar包(带静态资源)方法

    [Maven]在pom.xml文件中使用resources插件的小作用 不过war包比较实用,毕竟独立的tomcat比较好控制

  8. [UOJ#461]新年的Dog划分[二分图染色、二分]

    题意 给你一张无向连通图,你并不知道有哪些边,你首先要回答这张图是否是二分图,如果是,回答这张图黑白染色过后的任意一个点集.你需要在2000次询问内找到结果,每次你可以询问原图中一个边集删掉后是否还连 ...

  9. [THUSC2017]巧克力[斯坦纳树、随机化]

    题意 题目链接 分析 对于第一问,如果颜色数量比较少的话可以 \(\binom{cnt}{k}\) 枚举最终连通块中的 \(k\) 种颜色,然后利用斯坦纳树求解. 如果颜色比较多,考虑将所有的颜色重新 ...

  10. 内存和CPU资源控制

    数据库系统的资源是指内存和CPU(处理器)资源,拥有资源的多寡,决定了数据查询的性能.当一个SQL Server实例上,拥有多个独立的工作负载(workload)时,使用资源管理器(Resource ...