bzoj 4196 树链剖分 模板
[Noi2015]软件包管理器
Time Limit: 10 Sec Memory Limit: 512 MB
Submit: 2135 Solved: 1232
[Submit][Status][Discuss]
Description
Linux用户和OSX用户一定对软件包管理器不会陌生。通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖(即下载安装这个软件包的安装所依赖的其它软件包),完成所有的配置。Debian/Ubuntu使用的apt-get,Fedora/CentOS使用的yum,以及OSX下可用的homebrew都是优秀的软件包管理器。
Input
输入文件的第1行包含1个正整数n,表示软件包的总数。软件包从0开始编号。
Output
输出文件包括q行。
Sample Input
0 0 0 1 1 5
5
install 5
install 6
uninstall 1
install 4
uninstall 0
Sample Output
1
3
2
3
HINT
一开始所有的软件包都处于未安装状态。
Source
传说中的noi树链剖分sb题
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
const int maxn = ;
const int maxm = ;
int g[maxn],v[maxm],next[maxm],eid;
int size[maxn],son[maxn],top[maxn],f[maxn];
int st[maxn],ed[maxn],vid;
int n,m,x;
char op[]; void addedge(int a,int b) {
v[eid]=b; next[eid]=g[a]; g[a]=eid++;
} struct Segtree {
#define lc(x) ((x)<<1)
#define rc(x) (((x)<<1)|1) int sumv[maxm],sam[maxm];
int l[maxm],r[maxm]; void update(int x) {
sumv[x]=sumv[lc(x)]+sumv[rc(x)];
} void push(int x) {
if(sam[x]==-) return;
sam[lc(x)]=sam[x];
sumv[lc(x)]=sam[x]*(r[lc(x)]-l[lc(x)]+);
sam[rc(x)]=sam[x];
sumv[rc(x)]=sam[x]*(r[rc(x)]-l[rc(x)]+);
sam[x]=-;
} void change(int x,int L,int R,int val) {
if(R<l[x] || L>r[x]) return;
if(L<=l[x] && r[x]<=R) {
sam[x]=val;
sumv[x]=(r[x]-l[x]+)*val;
return;
}
push(x);
change(lc(x),L,R,val);
change(rc(x),L,R,val);
update(x);
} int query(int x,int L,int R) {
if(R<l[x] || L>r[x]) return ;
if(L<=l[x] && r[x]<=R) return sumv[x];
push(x);
return (query(lc(x),L,R)+query(rc(x),L,R));
} void build(int x,int L,int R) {
l[x]=L; r[x]=R; sam[x]=-;
if(L==R) return;
int mid=(L+R)>>;
build(lc(x),L,mid);
build(rc(x),mid+,R);
} }seg; void dfs1(int u) {
size[u]=;
for(int i=g[u];~i;i=next[i]) {
dfs1(v[i]);
size[u]+=size[v[i]];
if(size[v[i]]>size[son[u]]) son[u]=v[i];
}
} void dfs2(int u,int r) {
top[u]=r; st[u]=++vid;
if(son[u]) dfs2(son[u],r);
for(int i=g[u];~i;i=next[i]) if(v[i] != son[u])
dfs2(v[i],v[i]);
ed[u]=vid;
} void solve(int x) {
int res=;
while(x) {
res+=(st[x]-st[top[x]]+)-seg.query(,st[top[x]],st[x]);
seg.change(,st[top[x]],st[x],);
x=top[x];
x=f[x];
}
printf("%d\n",res);
}
int main()
{
memset(g,-,sizeof(g));
scanf("%d",&n);
for(int i=;i<=n;i++) {
scanf("%d",&f[i]);
f[i]++;
addedge(f[i],i);
}
seg.build(,,n);
dfs1(); dfs2(,);
scanf("%d",&m);
while(m--) {
scanf("%s%d",op,&x);
x++;
if(op[]=='i') solve(x);
else {
printf("%d\n",seg.query(,st[x],ed[x]));
seg.change(,st[x],ed[x],);
}
}
return ;
}
代码不是我的,lazy boy
bzoj 4196 树链剖分 模板的更多相关文章
- BZOJ 2243 染色 | 树链剖分模板题进阶版
BZOJ 2243 染色 | 树链剖分模板题进阶版 这道题呢~就是个带区间修改的树链剖分~ 如何区间修改?跟树链剖分的区间询问一个道理,再加上线段树的区间修改就好了. 这道题要注意的是,无论是线段树上 ...
- 算法复习——树链剖分模板(bzoj1036)
题目: 题目背景 ZJOI2008 DAY1 T4 题目描述 一棵树上有 n 个节点,编号分别为 1 到 n ,每个节点都有一个权值 w .我们将以下面的形式来要求你对这棵树完成一些操作:I.CHAN ...
- Hdu 5274 Dylans loves tree (树链剖分模板)
Hdu 5274 Dylans loves tree (树链剖分模板) 题目传送门 #include <queue> #include <cmath> #include < ...
- BZOJ 1036 树的统计Count 树链剖分模板题
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1036 题目大意: 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将 ...
- BZOJ 1036 [ZJOI2008]树的统计Count | 树链剖分模板
原题链接 树链剖分的模板题:在点带权树树上维护路径和,最大值和单点修改 这里给出几个定义 以任意点为根,然后记 size (u ) 为以 u 为根的子树的结点个数,令 v 为 u 所有儿子中 size ...
- QTREE 树链剖分---模板 spoj QTREE
<树链剖分及其应用> 一文讲得非常清楚,我一早上就把他学会了并且A了这题的入门题. spoj QTREE 题目: 给出一棵树,有两种操作: 1.修改一条边的边权. 2.询问节点a到b的最大 ...
- bzoj1036 [ZJOI2008]树的统计Count 树链剖分模板题
[ZJOI2008]树的统计Count Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成 一些操作: I. CHANGE u ...
- bzoj1036 树的统计 树链剖分模板
题意:给出树上任意两点,求路径上的值的和与最大值,带单点修改操作 树链剖分思路: 1.对树进行dfs求出点的深度和父亲节点,然后求出轻重儿子(重儿子就是点最多的那个子树,其余都是轻儿子),用一个son ...
- 洛谷 P3384 树链剖分(模板题)
题目描述 如题,已知一棵包含N个结点的树(连通且无环),每个节点上包含一个数值,需要支持以下操作: 操作1: 格式: 1 x y z 表示将树从x到y结点最短路径上所有节点的值都加上z 操作2: 格式 ...
随机推荐
- 【解题报告】AtCoder ABC115 (附英文题目)
------------------------------迟到的AK---------------------------------- A - Christmas Eve Eve Eve Time ...
- Java - 若try中有return语句,finally会执行吗?在return之前还是之后呢?
会执行,在方法return动作之前,return语句执行之后,若finally中再有return语句,则此方法以finally的return作为最终返回,若finally中无return语句,则此方法 ...
- git 命令汇总
本地库处理 git init 初始化仓库 git clone [地址] 下载项目 git status 查看当前暂存等状态 git add 添加暂存 cat .git/config 查看git配置 l ...
- mysql六:数据备份、pymysql模块
一 IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具 掌握: #1. 测试+链接数据库 #2. 新建库 #3. 新建表,新增字段+类型+约束 #4. 设计表 ...
- vue.js 独立引用css文件图片路径错误
vue的环境是用vue-cli,写在vue文件的图片引用build之后的路径都没什么问题 但是有的时候我们会有一些公共的css文件单独的放在assets目录下 如下图所示 这里当build后发现写在c ...
- js中正则表达式与Python中正则表达式的区别
今天女票让我帮她写一个js中的正则,来提取电话号码,对于正则规则来说,js与python是基本没有区别的,重点的区别是在一些函数与方法中. python中的正则提取: import re str = ...
- IIC如何释放数据总线? 为什么=1就是释放?
最近看IIC原理,释放一词经常用遇到,在nxp的标准中也有看到,有点疑惑,因此百度,在百度知道中,有大佬的解释,可以看看何为“释放”,结合数字电子技术,应该可以理解了. 下面总结了一下三个解释何为“释 ...
- 其它- in-place
in-place 刷编程题的时候,经常遇到题目要求do in-place.所以就上网搜了相关概念,简单总结一下. in-place操作,意思是所有的操作都是”就地“操作,不允许进行移动,或者称作 ...
- luogu3810 【模板】三维偏序(陌上花开)
ref1 ref2 ref3 ref4 #include <algorithm> #include <iostream> #include <cstdio> usi ...
- MOTCF 没时间解释了 条件竞争漏洞
moctf 没时间解释了 条件竞争漏洞 题目链接 条件竞争: 在本题目中,上传文件的时候服务器无条件的接收任何类型的文件,但是你上传之后服务器会给你的文件内容修改为too slow. 比如你上传了一句 ...