题解

我们可以发现,背包有结合律。

也就是先加入元素 \(a\) 再加入元素 \(b\) 和 \(c\),与先加入元素 \(a\) 后再与只有元素 \(b\) 和元素 \(c\) 的背包合并,得到的背包数组是不会发生改变的。

所以我们很容易想到用线段树来做这道题。

但是线段树太慢了,于是我们就理所当然地写了一个猫树。

然后

我们算了算,发现这个代码的空间有 \(500\) 多 MB(

于是我们就得把猫树的空间给优化一下。

我们发现在执行 Build 的时候,在递归结束后该子树的信息就不会再发生改变了。我们可以在此时进行查询,然后删掉这个子树的信息。

通俗点儿说就是把子树给滚掉。

要在建树时进行查询只需要离线存下询问就行了。

我们就成功地优化掉了一个 \(O(\log n)\),空间复杂度能够接受。

code:

#include<cstdio>
#include<vector>
const int M=4e4+5;
int n,m,c[M],v[M],ans[200005];
int back[M][205];
std::vector<int>l[M<<2],r[M<<2],t[M<<2],id[M<<2];
inline int max(const int&a,const int&b){
return a>b?a:b;
}
inline void trans(int*tar,int*ori,const int&c,const int&v){
for(register int i=0;i<=200;++i)tar[i]=ori[i];
for(register int i=200;i>=c;--i)tar[i]=max(tar[i],tar[i-c]+v);
}
inline int Q(const int&L,const int&R,const int&m){
register int i,ans=0;
if(L==R)for(i=0;i<=m;++i)ans=max(ans,back[L][i]);
else for(i=0;i<=m;++i)ans=max(ans,back[L][i]+back[R][m-i]);
return ans;
}
void Solve(int u,int L=1,int R=n){
register int i;
if(L==R)trans(back[L],*back,c[L],v[L]);
else{
register int mid=L+R>>1;
Solve(u<<1,L,mid);Solve(u<<1|1,mid+1,R);
trans(back[mid],*back,c[mid],v[mid]);trans(back[mid+1],*back,c[mid+1],v[mid+1]);
for(i=mid-1;i>=L;--i)trans(back[i],back[i+1],c[i],v[i]);
for(i=mid+2;i<=R;++i)trans(back[i],back[i-1],c[i],v[i]);
}
for(i=0;i<t[u].size();++i)ans[id[u][i]]=Q(l[u][i],r[u][i],t[u][i]);
}
inline void Insert(int u,int ql,int qr,int qt,int qd,int L=1,int R=n){
if(L==R){
l[u].push_back(ql);r[u].push_back(qr);t[u].push_back(qt);id[u].push_back(qd);
return;
}
int mid=L+R>>1;
if(qr<=mid)return Insert(u<<1,ql,qr,qt,qd,L,mid);
if(ql>mid)return Insert(u<<1|1,ql,qr,qt,qd,mid+1,R);
l[u].push_back(ql);r[u].push_back(qr);t[u].push_back(qt);id[u].push_back(qd);
}
signed main(){
register int i,L,R,t;
scanf("%d%d",&n,&m);
for(i=1;i<=n;++i)scanf("%d",c+i);
for(i=1;i<=n;++i)scanf("%d",v+i);
for(i=1;i<=m;++i){
scanf("%d%d%d",&L,&R,&t);
Insert(1,L,R,t,i);
}
Solve(1);
for(i=1;i<=m;++i)printf("%d\n",ans[i]);
}

LGP6240题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. Kubernetes实战之部署ELK Stack收集平台日志

    主要内容 1 ELK概念 2 K8S需要收集哪些日志 3 ELK Stack日志方案 4 容器中的日志怎么收集 5 K8S平台中应用日志收集 准备环境 一套正常运行的k8s集群,kubeadm安装部署 ...

  2. UIFont

    UIFont代表字体,常见创建方法有以下几个:+ (UIFont *)systemFontOfSize:(CGFloat)fontSize; 系统默认字体+ (UIFont *)boldSystemF ...

  3. 经常使用的系统类Math、Arrays、System、BigInteger和BigDecimal以及日期类,时间戳

    一.Math 常用类: //看看Math常用的方法(静态方法)//1.abs绝对值int abs = Math . abs(-9);System. out . printLn(abs);//9//2. ...

  4. 用Java模拟实现对系统文件以目录的拷贝功能

    要用Java对单个文件拷贝的话,其实思路很简单,循环读取被拷贝文件,放入byte数组,然后写入目标文件.当然我们也可以借助现有的类去完成,如InputStream中的transferTo()方法就可以 ...

  5. 到底什么是TORCH.NN?

    该教程是在notebook上运行的,而不是脚本,下载notebook文件. PyTorch提供了设计优雅的模块和类:torch.nn, torch.optim, Dataset, DataLoader ...

  6. Java在算法题中的输入问题

    Java在算法题中的输入问题 在写算法题的时候,经常因为数据的输入问题而导致卡壳,其中最常见的就是数据输入无法结束. 1.给定范围,确定输入几个数据 直接使用普通的Scanner输入数据范围,然后使用 ...

  7. suse 12 利用缓存创建本地源供内网服务使用

    文章目录 服务端获取 添加源 刷新源 清除缓存 安装软件 获取rpm包 客户端测试 zypper --help 前言: 其实,咱也不知道为啥写了这篇博客,咱就是想学一学suse,咱也不会,咱也只能学, ...

  8. CoRR 2015 | MXNet: A Flexible and Efficient Machine Learning Library for Heterogeneous Distributed Systems

    MXNet是一个支持多种编程语言的机器学习库,使用MXNet可以方便地实现机器学习算法,尤其是深度神经网络.通过嵌入在宿主语言中,它将声明式符号表达与命令式张量计算相结合.它提供自动求导以计算梯度.M ...

  9. ARM7、ARM9、ARM11、ARM-Cortex系列的关系

    参考资料: https://zhuanlan.zhihu.com/p/92315825 https://zhuanlan.zhihu.com/p/82337495 ARM是Advanced RISC ...

  10. Spring Boot 启动特别慢的问题

    Q:debug模式下代码编译没有问题,本来10 ms左右可以启动的项目,却耗时了3000多ms,why? A:删除项目中的断点,留几个要用的就行. 至于怎么一键删除所有断点,请自行搜索! 一度以为我的 ...