#\(\mathcal{\color{red}{Description}}\)

\(Link\)

一道\(zz\)的树剖题\(qwq\)。

#\(\mathcal{\color{red}{Solution}}\)

我天\(NOI\)怎么可能有这种水题啊……

很显然的就是 线段树区间染色 + 统计根到每个节点的距离 + 子树和 + 修改子树 ……

纯纯的板子啊!

\(emmmmm\)于是这道题就完了~

#include <cstdio>
#include <vector>
#include <iostream>
#define il inline
#define MAXN 200010
#define ls(x) (x << 1)
#define rs(x) (x << 1 | 1)
#define mid ((l + r) >> 1) using namespace std ;
char in[30] ;
vector <int> sons[MAXN] ; int Id[MAXN], tot ;
int dis[MAXN << 1], s[MAXN << 1], tag[MAXN << 1], i ;
int N, M, In, fa[MAXN], dep[MAXN], Top[MAXN], sub[MAXN], hs[MAXN] ; inline int qrr(){
int k = 0 ; char c = getchar() ;
while (c < '0' || c > '9') c = getchar() ;
while (c <= '9' && c >= '0') k = (k << 1) + (k << 3) + c - 48, c = getchar() ;
return k ;
}
void _dfs1(int deep, int now, int f){
dep[now] = deep, fa[now] = f ; sub[now] = 1 ;
int _hs = -1 ;
for (int k = 0 ; k < sons[now].size() ; ++ k){
_dfs1(deep + 1, sons[now][k], now) ;
sub[now] += sub[sons[now][k]] ;
if(sub[sons[now][k]] > _hs)
_hs = sub[sons[now][k]], hs[now] = sons[now][k] ;
}
}
void _dfs2(int now, int Tp){
Top[now] = Tp, Id[now] = ++ tot ;
if (!hs[now]) return ;
_dfs2(hs[now], Tp) ;
for (int k = 0 ; k < sons[now].size() ; ++ k){
if (sons[now][k] == hs[now]) continue ;
_dfs2(sons[now][k], sons[now][k]) ;
}
}
void build(int rt, int l, int r){
if (l == r) {dis[rt] = 1 ; return ;}
build(ls(rt), l, mid) ;
build(rs(rt), mid + 1, r) ;
dis[rt] = dis[ls(rt)] + dis[rs(rt)] ;
}
il void p_d(int rt, int l, int r){
if(tag[rt] != -1){
s[ls(rt)] = (mid - l + 1) * tag[rt] ;
s[rs(rt)] = (r - mid) * tag[rt] ;
tag[ls(rt)] = tag[rs(rt)] = tag[rt] ;
tag[rt] = -1 ;
}
}
int query_D(int rt, int l, int r, int ql, int qr){
int res = 0 ;
if (ql <= l && r <= qr){res += dis[rt] ; return res ;}
if (ql <= mid) res += query_D(ls(rt), l, mid, ql, qr) ;
if (qr > mid) res += query_D(rs(rt), mid + 1, r, ql, qr) ;
return res ;
}
int query_C(int rt, int l, int r, int ql, int qr){
int res = 0 ;
if (ql <= l && r <= qr){res += s[rt] ; return res ;}
p_d(rt, l, r) ;
if (ql <= mid) res += query_C(ls(rt), l, mid, ql, qr) ;
if (qr > mid) res += query_C(rs(rt), mid + 1, r, ql, qr) ;
return res ;
}
void update_C(int rt, int l, int r, int ul, int ur, int k){
if (ul <= l && r <= ur){
s[rt] = (r - l + 1) * k ;
tag[rt] = k ;
return ;
}
p_d(rt, l, r) ;
if (ul <= mid) update_C(ls(rt), l, mid, ul, ur, k) ;
if (ur > mid) update_C(rs(rt), mid + 1, r, ul, ur, k) ;
s[rt] = s[rs(rt)] + s[ls(rt)] ;
}
inline void qv(int now){
int ans = 0, dif = 0 ;
while (Top[now] != Top[1]){
ans += query_D(1, 1, N, Id[Top[now]], Id[now]) ;
dif += query_C(1, 1, N, Id[Top[now]], Id[now]) ;
now = fa[Top[now]] ;
}
ans += query_D(1, 1, N, 1, Id[now]) ;
dif += query_C(1, 1, N, 1, Id[now]) ;
printf("%d\n", ans - dif) ;
}
inline void uv(int now){
while (Top[now] != Top[1]){
update_C(1, 1, N, Id[Top[now]], Id[now], 1) ;
now = fa[Top[now]] ;
}
update_C(1, 1, N, 1, Id[now], 1) ;
}
int main(){
//freopen("manager.in", "r", stdin) ;
//freopen("manager.out", "w", stdout) ;
N = qrr() ;
fill (tag + 1, tag + (MAXN << 1) + 1, -1) ;
for (i = 2; i <= N ;i ++){
fa[i] = qrr() + 1,
sons[fa[i]].push_back(i) ;
} M = qrr() ;
_dfs1(1, 1, 0), _dfs2(1, 1), build(1, 1, N) ;
for (i = 1; i <= M ; i ++){
scanf("%s", in) ;
if (in[0] == 'u'){
In = qrr() + 1 ;
printf("%d\n", query_C(1, 1, N, Id[In], Id[In] + sub[In] - 1)) ;
update_C(1, 1, N, Id[In], Id[In]+ sub[In] - 1, 0) ;
continue ;
}
In = qrr() + 1 ;
qv(In), uv(In) ;
}
}

番外:以下是三次评测:

最快的是\(qread + printf + O2\),其次是\(qread + printf\),最慢的是\(qread + cout\)……

[题解向] Luogu2146[NOI2015]软件包管理器的更多相关文章

  1. 题解 P2146 【[NOI2015]软件包管理器】

    题目大意 ​ 给你一棵树, 求一点到根的路径上有多少个未标记点并全标记, 和询问一个点的子树内有多少已标记点和撤销标记 解题方法 1: install 操作 ​ 这个操作是求一点到根的路径上有多少个未 ...

  2. luogu2146 [NOI2015]软件包管理器

    安装就把根节点到它全设为 1 删除就把以它为根的子树全设为 0 记得标记初始化为-1,因为标记是 0 的情况也是要处理的. #include <iostream> #include < ...

  3. 【题解】NOI2015软件包管理器

    [题解][P2146 NOI2015]软件包管理器 实际上就是树链剖分板子题. 对于\(install\)操作,直接查询它到\(0\)节点有多少已经安装了的,再用总数减去它. 对于\(uninstal ...

  4. 题解 P2146 [NOI2015]软件包管理器

    P2146 [NOI2015]软件包管理器 感觉代码比其他题解更简洁qwq 树链剖分模板题 install x:将1~x的路径上的节点全部变成1(安装x需要先安装1~x) uninstall x:将x ...

  5. Bzoj 4196: [Noi2015]软件包管理器 树链剖分

    4196: [Noi2015]软件包管理器 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 721  Solved: 419[Submit][Statu ...

  6. 【BZOJ4196】[Noi2015]软件包管理器 树链剖分

    [Noi2015]软件包管理器 树链剖分 Description Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从 ...

  7. [UOJ#128][BZOJ4196][Noi2015]软件包管理器

    [UOJ#128][BZOJ4196][Noi2015]软件包管理器 试题描述 Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管 ...

  8. BZOJ 4196: [Noi2015]软件包管理器 [树链剖分 DFS序]

    4196: [Noi2015]软件包管理器 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1352  Solved: 780[Submit][Stat ...

  9. [BZOJ4196][NOI2015]软件包管理器

    4196: [Noi2015]软件包管理器 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1040  Solved: 603[Submit][Stat ...

随机推荐

  1. Java之路---Day18(List集合)

    2019-11-05-23:03:28 List集合: java.util.List 接口继承自 Collection 接口,是单列集合的一个重要分支,习惯性地会将实现了List 接口的对象称为Lis ...

  2. Date+闭包

    date类: var  time=new.date() get date() 返回一个月中的某一天 get day () 返回一周中的某一天 get fullyear() 对象以四位数返回年份 get ...

  3. 文件转base64处理或转换blob对象链接

    一.文件转base64,代码: axios({ method: 'get', url: apiPath.common.downloaddUrl, responseType: 'blob'}).then ...

  4. 英文finaunce金融

    金融 1.指货币的发行.流通和回笼,贷款的发放和收回,存款的存入和提取,汇兑的往来等经济活动. 胡适<国际的中国>:“我们更想想这几年国内的资产阶级,为了贪图高利债的利益,拚命的借债给中国 ...

  5. web由http升级为https搭建

    nginx实现http访问 server { listen default_server; listen [::]: default_server; server_name _; root /usr/ ...

  6. 【异常】java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result.

    异常原因:没有指定数据精度导致数据运算无法正常结算 如执行下面的除法: ).divide(BigDecimal.valueOf()).intValue(); 指定精度后就可以了: ).divide(B ...

  7. Vagrant+VirtualBox虚拟环境

    Vagrant+VirtualBox虚拟环境 VagrantVirtualBox 软件安装 虚拟机基础配置 虚拟机创建 共享目录 配置网络 配置私有网络 配置公有网络 打包box与添加box 打包bo ...

  8. SRVCC B1,B2事件总结

    何为SRVCC? SRVCC(Single Radio Voice Call Continuity)是3GPP提出的一种VoLTE语音业务连续性方案,主要是为了解决当单射频UE 在LTE网络和2G/3 ...

  9. Linux 修改时区(PDT修改为CST)

    方法1: Linux 修改时区 本文链接:https://blog.csdn.net/Aritem/article/details/79213306 命令:tzselect 按照顺序依次输入5,9,1 ...

  10. Feign 报错:The bean 'service-producer.FeignClientSpecification', defined in null, could not be registered. A bean with that name has already been defined in null and overriding is disabled.

    报错: 2019-09-17 20:34:47.635 ERROR 59509 --- [ main] o.s.b.d.LoggingFailureAnalysisReporter : ******* ...