#树链剖分,背包#洛谷 5391 [Cnoi2019]青染之心
题目
Cirno初始有一个空的物品序列,一个大小为 \(V\) 的背包,现在你有 \(q\) 个操作,分为两种:
add \(x\) \(y\) : 表示加入一种体积为 \(x\), 价值为 \(y\) 的物品到序列末尾
erase : 表示删除序列末尾的物品
对于每个操作结束以后,你需要求出 :
假设序列中的每种物品都有无穷多个,Cirno的背包可以装下的物品最大价值和。
\(q,v\leq 2*10^4\)
分析
即使5s的限制,线段树分治也会超时
考虑删除实际上就是回溯到上一个版本,那么可以按照这样建一棵关系树,
直接按照这棵关系树跑就可以做到时间复杂度严格\(O(qv)\),但是会MLE,
考虑树链剖分的一个性质,一个点到根节点不会经过超过\(\log\)条轻边,
则只需要保留重儿子信息即可,空间复杂度\(O(v\log_2q)\)
代码
#include <cstdio>
#include <cctype>
#define rr register
using namespace std;
const int N=20011; struct node{int y,next;}e[N];
int siz[N],big[N],dp[15][N],ans[N],as[N],et,rk[N],w[N],c[N],Q,m,n,Top,stac[N];
inline signed iut(){
rr int ans=0; rr char c=getchar();
while (!isdigit(c)) c=getchar();
while (isdigit(c)) ans=(ans<<3)+(ans<<1)+(c^48),c=getchar();
return ans;
}
inline void print(int ans){
if (ans>9) print(ans/10);
putchar(ans%10+48);
}
inline signed max(int a,int b){return a>b?a:b;}
inline void dfs1(int x){
siz[x]=1;
for (rr int i=as[x],SIZ=-1;i;i=e[i].next){
dfs1(e[i].y),siz[x]+=siz[e[i].y];
if (SIZ<siz[e[i].y]) SIZ=siz[e[i].y],big[x]=e[i].y;
}
}
inline void dfs2(int x,int d,int las){
for (rr int i=0;i<w[x];++i) dp[d][i]=dp[las][i];
for (rr int i=w[x];i<=m;++i) dp[d][i]=max(dp[las][i],dp[d][i-w[x]]+c[x]);
ans[x]=dp[d][m];
for (rr int i=as[x];i;i=e[i].next)
if (e[i].y!=big[x]) dfs2(e[i].y,d+1,d);
if (big[x]) dfs2(big[x],d,d);
}
signed main(){
Q=iut(),m=iut();
for (rr int i=1;i<=Q;++i){
rr char ch=getchar();
while (ch!='a'&&ch!='e') ch=getchar();
if (ch=='e') --Top,getchar(),getchar(),getchar(),getchar();
else {
w[++n]=iut(),c[n]=iut();
if (stac[Top]) e[++et]=(node){n,as[stac[Top]]},as[stac[Top]]=et;
stac[++Top]=n;
}
if (Top) rk[i]=stac[Top];
}
for (rr int i=1;i<=n;++i)
if (!siz[i]) dfs1(i),dfs2(i,1,0);
for (rr int i=1;i<=Q;++i) print(ans[rk[i]]),putchar(10);
return 0;
}
#树链剖分,背包#洛谷 5391 [Cnoi2019]青染之心的更多相关文章
- 洛谷 P5391 - [Cnoi2019]青染之心
洛谷题面传送门 介绍一种假做法,期望复杂度应该比较优秀,但可以卡掉( 首先这个问题显然严格强于只有添加元素的情况对吧,而只有添加元素的情况就是一个普通的背包,而只有插入操作的版本复杂度就已经达到了 \ ...
- 【树链剖分】洛谷P3379 树链剖分求LCA
题目描述 如题,给定一棵有根多叉树,请求出指定两个点直接最近的公共祖先. 输入输出格式 输入格式: 第一行包含三个正整数N.M.S,分别表示树的结点个数.询问的个数和树根结点的序号. 接下来N-1行每 ...
- 树链剖分模板(洛谷P3384)
洛谷P3384 #include <bits/stdc++.h> #define DBG(x) cerr << #x << " = " < ...
- 树链剖分( 洛谷P3384 )
我们有时候遇到这样一类题目,让我们维护树上路径的某些信息,这个时候发现我们无法用线段树或者树状数组来维护这些信息,那么我们就有着一种新的数据结构,树剖:将一棵树划分成若干条链,用数据结构去维护每条链, ...
- 【树链剖分】洛谷P3384树剖模板
题目描述 如题,已知一棵包含N个结点的树(连通且无环),每个节点上包含一个数值,需要支持以下操作: 操作1: 格式: 1 x y z 表示将树从x到y结点最短路径上所有节点的值都加上z 操作2: 格式 ...
- 树链剖分【洛谷P4114】 Qtree1
P4114 Qtree1 题目描述 给定一棵n个节点的树,有两个操作: CHANGE i ti 把第i条边的边权变成ti QUERY a b 输出从a到b的路径中最大的边权,当a=b的时候,输出0 码 ...
- 树链剖分【洛谷P2590】 [ZJOI2008]树的统计
P2590 [ZJOI2008]树的统计 题目描述 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w. 我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把 ...
- 树链剖分【洛谷P1505】 [国家集训队]旅游
P1505 [国家集训队]旅游 题目描述 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城 ...
- 树链剖分【洛谷P3833】 [SHOI2012]魔法树
P3833 [SHOI2012]魔法树 题目描述 Harry Potter 新学了一种魔法:可以让改变树上的果子个数.满心欢喜的他找到了一个巨大的果树,来试验他的新法术. 这棵果树共有N个节点,其中节 ...
- 洛谷 P3384 【模板】树链剖分
树链剖分 将一棵树的每个节点到它所有子节点中子树和(所包含的点的个数)最大的那个子节点的这条边标记为"重边". 将其他的边标记为"轻边". 若果一个非根节点的子 ...
随机推荐
- Kotlin 函数 与 lambda 表达式
一.函数 代码块函数体: fun sum(x: Int, y: Int): Int { return x + y } 表达式函数体: fun sum(x: Int, y: Int) = x + y 使 ...
- 【Application Insights】使用CURL命令向Application Insgihts发送测试数据
问题描述 在使用App Service或者Kubernetes等服务时,需要收集一些日志数据并且发送到Application Insights中,当使用SDK或者是服务自带的Application I ...
- 理解LLMOps: Large Language Model Operations
理解LLMOps: Large Language Model Operations 对于像我一样的小白来说,本文是一篇非常不错的LLMs入门介绍文档.来自:Understanding LLMOps: ...
- Python实现企业微信自动打卡程序二:跳过节假日,随机打卡时间,定时任务,失败通知
一.介绍 在上节 Python实现企业微信上下班自动打卡程序内容之后,我们继续优化自动打卡程序.接下来增加如下内容: 实现打卡时间随机范围 处理节假日不打卡的情况 实现定时调度打卡 打卡成功或失败通知 ...
- idea 暂存 Stash Changes Git/Repository/Stash Changes 恢复暂存 UnStash Changes
idea 暂存 Stash Changes Git/Repository/Stash Changes 恢复暂存 UnStash Changes git stash save "save me ...
- electron vite2 vue3 安装 cvep my-electron-cvep
npm config set registry=https://registry.npm.taobao.org/ npm config set ELECTRON_MIRROR=http://npm.t ...
- manjaroLinux-xfce4设置显示桌面快捷键
1.打开窗口快捷键 2.寻找显示桌面 3.设置快捷键 啊!简单的我都不想写了,这不是为让像以前的"我"--小白,食用性更好一点吗?
- Kotlin 语法糖(对象不为空返回自身,为空返回其他)
原文地址: Kotlin 语法糖(对象不为空返回自身,为空返回其他) - Stars-One的杂货小窝 开发中,经常会有这样逻辑: 判断对象如果不为空,则取对象本身; 为空,则得到其他对象; 然后每次 ...
- 四种方式实现点击chrome链接在ie中显示页面
1.c++ socket通过浏览器在ie中打开指定url github源码:https://github.com/iamzken/cpp-open-ie 2.vb生成exe,url访问exe启动ie并 ...
- B站上传视频时各分辨率最佳的码率及格式参数
相关链接:表格源文件