题解

连树剖我都写跪一次,我现在怎么那么老年啊= =

简直滚粗预定了啊。。

我们线段树维护树剖只需要资瓷区间覆盖和区间求和就好了

安装的时候看看自己到根有多少包装了,dep减去这个数量就好

卸载的时候看看子树里有多少包安装了就行

代码

#include <bits/stdc++.h>
//#define ivorysi
#define enter putchar('\n')
#define space putchar(' ')
#define fi first
#define se second
#define pb push_back
#define mp make_pair
#define eps 1e-8
#define mo 974711
#define MAXN 100005
#define pii pair<int,int>
using namespace std;
typedef long long int64;
typedef double db;
template<class T>
void read(T &res) {
res = 0;char c = getchar();T f = 1;
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 + c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {putchar('-');x = -x;}
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
} struct node {
int to,next;
}E[MAXN * 2];
struct Tr_node {
int L,R;
int sum,cover;
}tr[MAXN * 4];
int head[MAXN],sumE,N,Q;
int dep[MAXN],fa[MAXN],siz[MAXN],son[MAXN];
int dfn[MAXN],idx,top[MAXN],L[MAXN];
void add_cover(int u,int v) {
if(v == 1) {
tr[u].sum = tr[u].R - tr[u].L + 1;
tr[u].cover = 1;
}
else {
tr[u].sum = 0;
tr[u].cover = -1;
}
}
void push_down(int u) {
if(tr[u].cover) {
add_cover(u << 1,tr[u].cover);
add_cover(u << 1 | 1,tr[u].cover);
tr[u].cover = 0;
}
}
void update(int u) {
tr[u].sum = tr[u << 1].sum + tr[u << 1 | 1].sum;
}
void add(int u,int v) {
E[++sumE].to = v;
E[sumE].next = head[u];
head[u] = sumE;
}
void dfs1(int u) {
dep[u] = dep[fa[u]] + 1;
siz[u] = 1;
for(int i = head[u] ; i ; i = E[i].next) {
int v = E[i].to;
if(v != fa[u]) {
fa[v] = u;
dfs1(v);
siz[u] += siz[v];
if(siz[v] > siz[son[u]]) son[u] = v;
}
}
}
void dfs2(int u) {
dfn[u] = ++idx;
L[idx] = u;
if(!top[u]) top[u] = u;
if(son[u]) {
top[son[u]] = top[u];
dfs2(son[u]);
}
for(int i = head[u] ; i ; i = E[i].next) {
int v = E[i].to;
if(v != fa[u] && v != son[u]) dfs2(v);
}
}
void build(int u,int l,int r) {
tr[u].L = l;tr[u].R = r;
tr[u].cover = tr[u].sum = 0;
if(l == r) return;
int mid = (l + r) >> 1;
build(u << 1,l,mid);
build(u << 1 | 1,mid + 1,r);
}
int Query(int u,int l,int r) {
if(tr[u].L == l && tr[u].R == r) return tr[u].sum;
push_down(u);
int mid = (tr[u].L + tr[u].R) >> 1;
if(r <= mid) Query(u << 1,l,r);
else if(l > mid) Query(u << 1 | 1,l,r);
else return Query(u << 1,l,mid) + Query(u << 1 | 1,mid + 1,r);
}
void Cover(int u,int l,int r,int v) {
if(tr[u].L == l && tr[u].R == r) {
add_cover(u,v);
return;
}
push_down(u);
int mid = (tr[u].L + tr[u].R) >> 1;
if(r <= mid) Cover(u << 1,l,r,v);
else if(l > mid) Cover(u << 1 | 1,l,r,v);
else Cover(u << 1,l,mid,v),Cover(u << 1 | 1,mid + 1,r,v);
update(u);
} void Change(int u,int v) {
while(u) {
Cover(1,dfn[top[u]],dfn[u],v);
u = fa[top[u]];
}
}
int Query_Tr(int u) {
int res = 0;
while(u) {
res += Query(1,dfn[top[u]],dfn[u]);
u = fa[top[u]];
}
return res;
}
void Solve() {
read(N);
int p;
for(int i = 2 ; i <= N ; ++i) {
read(p);++p;add(i,p);add(p,i);
}
dfs1(1);dfs2(1);
build(1,1,N);
read(Q);
char s[20];
for(int i = 1 ; i <= Q ; ++i) {
scanf("%s",s + 1);read(p);
++p;
if(s[1] == 'i') {
out(dep[p] - Query_Tr(p));
Change(p,1);
}
else {
out(Query(1,dfn[p],dfn[p] + siz[p] - 1));
Cover(1,dfn[p],dfn[p] + siz[p] - 1,-1);
}
enter;
}
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Solve();
return 0;
}

最新文章

  1. Mysql Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation &#39;=&#39;
  2. HandlerThread 用法
  3. 媒体查询判断ipad与iPhone各版本i
  4. python默认的是17位小数的精度,但是这里有一个问题,就是当我们的计算需要使用更高的精度(超过17位小数)的时候该怎么做呢?
  5. dw添加emmet
  6. 开机自动播放音乐的vbs
  7. c#模拟百度电击器方案
  8. SpringMVC的简单示例
  9. mooc
  10. ANDROID 自动生成动态表格for
  11. Ext.NET webform
  12. [Java]LeetCode117. 填充同一层的兄弟节点 II | Populating Next Right Pointers in Each Node II
  13. oAuth2授权协议 &amp; 微信授权登陆和绑定 &amp; 多环境共用一个微信开发平台回调设置
  14. CF 670C Cinema(算竞进阶习题)
  15. 安装虚拟环境和Flask
  16. JavaScript中标识符的命名
  17. PHP发送HEAD方法请求
  18. JSP中的动态包含和静态包含的区别
  19. HBase 架构与工作原理1 - HBase 的数据模型
  20. Add words to your picture

热门文章

  1. 手机 safari mac 调试
  2. 新式类 VS 经典类
  3. [DeeplearningAI笔记]序列模型1.7-1.9RNN对新序列采样/GRU门控循环神经网络
  4. numpy数组中冒号和负号的含义
  5. springsecurity remember-me 功能
  6. react UI组件库 Salt UI
  7. 【bzoj】2326 [HNOI2011]数学作业
  8. 2017ACM暑期多校联合训练 - Team 2 1008 HDU 6052 To my boyfriend (数学 模拟)
  9. sqlmap的使用方法 ——时光凉春衫薄
  10. uboot makefile构建分析-续