首页 技术 正文
技术 2022年11月15日
0 收藏 566 点赞 5,086 浏览 1353 个字

题目传送门:洛谷P3835

题意简述:

题面说的很清楚了。

题解:

考虑建立一棵每个节点都表示一个版本的树。

以初始版本 \(0\) 为根。对于第 \(i\) 个操作,从 \(v_i\) 向 \(i\) 连一条边,而边权则是 \(opt_i\) 和 \(x_i\) 的二元组,表示经过这条边上操作,可以达到下一个状态。

考虑使用权值树状数组维护操作。只需要实现单点加,查询前缀和以及树状数组上二分的操作即可。

树状数组提前插入 \(-2147483647\) 和 \(2147483647\) 两个数,方便统计。

因为权值范围太大,所以先离散化权值,再插入树状数组。

只需要从结点 \(0\) 开始 DFS ,进入子树时执行操作,退出子树时撤销操作即可。

 #include <cstdio>
#include <algorithm>
using namespace std; const int INF = 0x7fffffff;
const int MQ = ; int N, Q;
int faz[MQ], opt[MQ], a[MQ], b[MQ];
int Ans[MQ]; int eh[MQ], nxt[MQ], to[MQ], tot;
inline void ins(int x, int y) {
nxt[++tot] = eh[x]; to[tot] = y; eh[x] = tot;
} int B[MQ];
inline void Add(int i, int x) { for (; i <= N; i += i & -i) B[i] += x; }
inline int Qur(int i) { int A = ; for (; i; i -= i & -i) A += B[i]; return A; }
inline int BS(int x) { int p = ; for (int j = << ; j; j >>= ) if ((p | j) <= N && B[p | j] <= x) x -= B[p |= j]; return p;} void DFS(int u, int o, int x) {
int ok = ;
if (o == ) Add(x, );
if (o == ) {
if (Qur(x) == Qur(x - )) ok = ;
else Add(x, -);
}
if (o == ) Ans[u] = Qur(x - );
if (o == ) Ans[u] = b[BS(x) + ];
if (o == ) Ans[u] = b[BS(Qur(x - ) - ) + ];
if (o == ) Ans[u] = b[BS(Qur(x)) + ]; for (int i = eh[u]; i; i = nxt[i])
DFS(to[i], opt[to[i]], a[to[i]]); if (o == ) Add(x, -);
if (o == && ok) Add(x, );
} int main() {
scanf("%d", &Q);
for (int i = ; i <= Q; ++i) {
scanf("%d%d%d", &faz[i], &opt[i], &a[i]);
if (opt[i] != )
b[++N] = a[i];
} b[++N] = -INF, b[++N] = INF;
sort(b + , b + N + );
N = unique(b + , b + N + ) - b - ;
for (int i = ; i <= Q; ++i) {
ins(faz[i], i);
if (opt[i] != )
a[i] = lower_bound(b + , b + N + , a[i]) - b;
}
Add(, ), Add(N, );
DFS(, , );
for (int i = ; i <= Q; ++i) {
if(opt[i] > )
printf("%d\n", Ans[i]);
}
return ;
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,492
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,907
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,740
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,493
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,132
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,295