题目

求出从前往后的背包\(f_{i,j}\)和从后往前的背包\(F_{i,j}\)。

那么对于询问\((d,e)\),答案就是\(\max\limits_{i=0}^e f_{d-1,i}+F_{d+1,e-i}\)。

然后就是单调队列优化多重背包。

记物品有\(c[i]\)个,价值为\(v[i]\),代价为\(w[i]\)。

多重背包的转移\(f[i][j]=\max\limits_{k=0}^{min(c[i],\lfloor\frac j{w[i]}\rfloor)}(f[i-1][j-w[i]*k]+v[i]*k)\)

令\(s=\lfloor\frac j{w[i]}\rfloor,d=j-w[i]*s\)。

则\(f[i][j]=\max\limits_{k=0}^{min(c[i],\lfloor\frac j{w[i]}\rfloor)}(f[i-1][d+(s-k)*w[i]]+v[i]*k)\)

令\(k=s-k\),则\(f[i][j]=\max\limits_{k=max(0,s-c[i])}^{s}(f[i-1][d+k*w[i]]-v[i]*k)+v[i]*s\)

也就是对于\(f[i][d+k*w[i]\),我们需要找到前面\(f[i-1][d+K*w[i]]-K*w[i](K\in[k-c[i],k])\)的最大值,然后加上\(k*w[i]\)。

我们将前面的所有\(f[i-1][d+K*w[i]]-K*w[i](K\in[k-c[i],k])\)放进一个单调队列,每次把队首的\(K\)小于\(k-c[i]\)的弹出,然后把当前的\(f[i][d+k*w[i]]\)加入队尾,然后取出队首更新答案。

这里我们可以用一个pair的deque来实现。

#include<bits/stdc++.h>
#define mp make_pair
#define P pair<int,int>
#define fir first
#define sec second
using namespace std;
const int N=1007,V=10007;
int read(){int x;scanf("%d",&x);return x;}
void max(int &a,int b){a=a>b? a:b;}
int c[N],w[N],v[N],d[N],e[N],f[N][V],F[N][V];
void cal(int *f,int i)
{
for(int d=0,k;d<w[i];++d)
{
deque<P>q{mp(0,f[d])};
for(k=1;k*w[i]+d<=10000;++k)
{
while(!q.empty()&&q.front().fir<k-c[i]) q.pop_front();
while(!q.empty()&&q.back().sec<=f[k*w[i]+d]-k*v[i]) q.pop_back();
q.push_back(mp(k,f[k*w[i]+d]-k*v[i])),max(f[k*w[i]+d],q.front().sec+k*v[i]);
}
}
}
int main()
{
int i,d,e,n,q,ans;
for(n=read(),i=1;i<=n;++i) w[i]=read(),v[i]=read(),c[i]=read();
for(i=1;i<=n;++i) memcpy(f[i],f[i-1],sizeof f[i]),cal(f[i],i);
for(i=n;i;--i) memcpy(F[i],F[i+1],sizeof F[i]),cal(F[i],i);
for(q=read();q;--q)
{
d=read()+1,e=read(),ans=0;
for(i=0;i<=e;++i) max(ans,f[d-1][i]+F[d+1][e-i]);
printf("%d\n",ans);
}
}

或者换成手写队列也行。不过我刚刚写锅了,懒得写了。反正deque常数挺小的。

Luogu P4095 [HEOI2013]Eden的新背包问题的更多相关文章

  1. luogu P4095 [HEOI2013]Eden 的新背包问题 多重背包 背包的合并

    LINK:Eden 的新背包问题 就是一个多重背包 每次去掉一个物品 询问钱数为w所能买到的最大值. 可以对于每次Q暴力dp 利用单调队列优化多重背包 这样复杂度是Qnm的. 发现过不了n==10的点 ...

  2. LUOGU P4095 [HEOI2013]Eden 的新背包问题

    题目描述 " 寄 没 有 地 址 的 信 ,这 样 的 情 绪 有 种 距 离 ,你 放 着 谁 的 歌 曲 ,是 怎 样 的 心 情 . 能 不 能 说 给 我 听 ." 失忆的 ...

  3. Luogu P4095 [HEOI2013]Eden 的新背包问题 思维/动规

    当时一直在想前缀和...多亏张队提醒... 从1到n背次包,保存每一个状态下的价值,就是不要把第一维压掉:再从n到1背一次,同样记住每种状态: 然后询问时相当于是max(前缀+后缀),当然前缀后缀中间 ...

  4. P4095 [HEOI2013]Eden 的新背包问题

    P4095 [HEOI2013]Eden 的新背包问题 题解 既然假定第 i 个物品不可以选,那么我们就设置两个数组 dpl[][] 正序选前i个物品,dpr[][] 倒序选前i个物品 ,价格不超过 ...

  5. 题解——洛谷P4095 [HEOI2013]Eden 的新背包问题(背包)

    思路很妙的背包 用了一些前缀和的思想 去掉了一个物品,我们可以从前i-1个和后i+1个推出答案 奇妙的思路 #include <cstdio> #include <algorithm ...

  6. BZOJ 3163: [Heoi2013]Eden的新背包问题( 背包dp )

    从左到右, 从右到左分别dp一次, 然后就可以回答询问了. ---------------------------------------------------------- #include< ...

  7. BZOJ3163&Codevs1886: [Heoi2013]Eden的新背包问题[分治优化dp]

    3163: [Heoi2013]Eden的新背包问题 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 428  Solved: 277[Submit][ ...

  8. 洛谷P4095||bzoj3163 [HEOI2013]Eden 的新背包问题

    https://www.luogu.org/problemnew/show/P4095 不太会.. 网上有神奇的做法: 第一种其实是暴力(复杂度3e8...)然而可以A.考虑多重背包,发现没有办法快速 ...

  9. bzoj 3163: [Heoi2013]Eden的新背包问题

    Description "寄没有地址的信,这样的情绪有种距离,你放着谁的歌曲,是怎样的心心静,能不能说给我听."失忆的Eden总想努力地回忆起过去,然而总是只能清晰地记得那种思念的 ...

随机推荐

  1. Nowcoder Monotonic Matrix ( Lindström–Gessel–Viennot lemma 定理 )

    题目链接 题意 : 在一个 n * m 的矩阵中放置 {0, 1, 2} 这三个数字.要求 每个元素 A(i, j) <= A(i+1, j) && A(i, j) <= ...

  2. CDOJ 图论专题 A.不是图论 强连通分量+拓扑排序 经典

    题目链接  在其中纠错第一次wa代码 #include <cstdio> #include <cstring> #include <cstdlib> #includ ...

  3. win10 + cuda10.0 + pytorch1.2 + CenterNet 环境搭建

    心血来潮,想跑个 CenterNet 检测瞅瞅...麻蛋,有非官方层 一.下载好 CenterNet 源码 https://github.com/xingyizhou/CenterNet 二.注意你需 ...

  4. Spark译文(三)

    Structured Streaming Programming Guide(结构化流编程指南) Overview(概貌) ·Structured Streaming是一种基于Spark SQL引擎的 ...

  5. CentOS版本禁用Ctrl+Alt+Del重启功能

    1  禁用Ctrl+Alt+Del重启功能(不重启系统的前提条件) 1.1  CentOS 6 ##查看/etc/inittab确认Ctrl+Alt+Del相关配置文件 cat /etc/initta ...

  6. Oracle11g RAC+DG搭建

    项目环境准备 3.1虚拟机配置 版本选择 注意Linux操作系统.此次项目我选择的版本是Oracle Enterprise Linux 5.4 内存的设置 本人电脑物理内存8G,由于此次实验要开三台虚 ...

  7. ztree复选框

    var setting = { check: { enable: true // chkboxType : { "Y" : "", "N" ...

  8. CommandLineRunner and ApplicationRunner

    1. Run spring boot as a standalone application (non-web) <?xml version="1.0" encoding=& ...

  9. windows 简单实用Elasticsearch

    官网下载地址:https://download.elasticsearch.org/elasticsearch/release/org/elasticsearch/distribution/zip/e ...

  10. Docker入门-常用命令

    Docker镜像操作 Docker运行容器前需要本地存在对应的镜像,如果本地不存在该镜像,Docker会从镜像仓库下载该镜像. 获取镜像 从Docker镜像仓库获取镜像的命令是docker pull. ...