[bzoj1146]网络管理
发现是链上的问题,所以树链剖分
发现要查询第k大,因为第k大不支持合并,所以要二分答案
二分答案后相当于询问一些区间内大于某数的数个数,直接线段树套平衡树即可
时间复杂度$o(nlog^{4}_n)$(跟$o(n^{2})$有什么区别)可以卡过
1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 100005
4 #define L (k<<1)
5 #define R (L+1)
6 #define mid (l+r>>1)
7 #define s(p) ch[k][p]
8 struct ji{
9 int nex,to;
10 }edge[N<<1];
11 int E,n,m,p,x,y,head[N],a[N],fa[N],sh[N],top[N],ma[N],id[N];
12 int V,ro[N<<2],sz[N*50],sum[N*50],ra[N*50],v[N*50],ch[N*50][2];
13 void add_edge(int x,int y){
14 edge[E].nex=head[x];
15 edge[E].to=y;
16 head[x]=E++;
17 }
18 void up(int k){
19 sz[k]=sz[s(0)]+sz[s(1)]+sum[k];
20 }
21 void rotate(int &k,int x,int p){
22 s(p)=ch[x][p^1];
23 ch[x][p^1]=k;
24 up(k);
25 up(k=x);
26 }
27 void add(int &k,int x){
28 if (!k){
29 v[k=++V]=x;
30 ra[k]=rand();
31 sz[k]=0;
32 }
33 sz[k]++;
34 if (v[k]==x){
35 sum[k]++;
36 return;
37 }
38 bool p=(v[k]<x);
39 add(s(p),x);
40 if (ra[k]>ra[s(p)])rotate(k,s(p),p);
41 }
42 void del(int &k,int x){
43 sz[k]--;
44 if (v[k]==x){
45 if (--sum[k])return;
46 sum[k]++;
47 if (s(0)*s(1)==0)k=s(0)+s(1);
48 else{
49 bool p=(ra[s(0)]>ra[s(1)]);
50 rotate(k,s(p),p);
51 del(k,x);
52 }
53 return;
54 }
55 del(s(v[k]<x),x);
56 }
57 int query(int k,int x){
58 if (!k)return 0;
59 if (v[k]==x)return sum[k]+sz[s(1)];
60 bool p=(v[k]<x);
61 return query(s(p),x)+(p^1)*(sum[k]+sz[s(1)]);
62 }
63 void update(int k,int l,int r,int x,int y,int z){
64 if (y!=-1)del(ro[k],y);
65 add(ro[k],z);
66 if (l==r)return;
67 if (x<=mid)update(L,l,mid,x,y,z);
68 else update(R,mid+1,r,x,y,z);
69 }
70 int query(int k,int l,int r,int x,int y,int z){
71 if ((l>y)||(x>r))return 0;
72 if ((x<=l)&&(r<=y))return query(ro[k],z);
73 return query(L,l,mid,x,y,z)+query(R,mid+1,r,x,y,z);
74 }
75 void dfs(int k,int f,int s){
76 fa[k]=f;
77 sh[k]=s;
78 sz[k]=1;
79 for(int i=head[k];i!=-1;i=edge[i].nex)
80 if (edge[i].to!=f){
81 dfs(edge[i].to,k,s+1);
82 sz[k]+=sz[edge[i].to];
83 if (sz[ma[k]]<sz[edge[i].to])ma[k]=edge[i].to;
84 }
85 }
86 void dfs2(int k,int t){
87 top[k]=t;
88 id[k]=++x;
89 update(1,1,n,x,-1,a[k]);
90 if (ma[k])dfs2(ma[k],t);
91 for(int i=head[k];i!=-1;i=edge[i].nex)
92 if ((edge[i].to!=fa[k])&&(edge[i].to!=ma[k]))dfs2(edge[i].to,edge[i].to);
93 }
94 int query(int x,int y,int z){
95 int ans=0;
96 while (top[x]!=top[y]){
97 if (sh[top[x]]<sh[top[y]])swap(x,y);
98 ans+=query(1,1,n,id[top[x]],id[x],z);
99 x=fa[top[x]];
100 }
101 if (id[x]>id[y])swap(x,y);
102 return ans+query(1,1,n,id[x],id[y],z);
103 }
104 int find(){
105 int l=0,r=100000000;
106 while (l<r){
107 int m=(l+r+1>>1);
108 if (query(x,y,m)>=p)l=m;
109 else r=m-1;
110 }
111 return l;
112 }
113 int main(){
114 srand(time(0));
115 scanf("%d%d",&n,&m);
116 for(int i=1;i<=n;i++)scanf("%d",&a[i]);
117 memset(head,-1,sizeof(head));
118 for(int i=1;i<n;i++){
119 scanf("%d%d",&x,&y);
120 add_edge(x,y);
121 add_edge(y,x);
122 }
123 dfs(1,0,0);
124 x=0;
125 dfs2(1,1);
126 for(int i=1;i<=m;i++){
127 scanf("%d%d%d",&p,&x,&y);
128 if (!p){
129 update(1,1,n,id[x],a[x],y);
130 a[x]=y;
131 continue;
132 }
133 if (query(x,y,0)<p)printf("invalid request!\n");
134 else printf("%d\n",find());
135 }
136 }
[bzoj1146]网络管理的更多相关文章
- [BZOJ1146][CTSC2008]网络管理Network
[BZOJ1146][CTSC2008]网络管理Network 试题描述 M公司是一个非常庞大的跨国公司,在许多国家都设有它的下属分支机构或部门.为了让分布在世界各地的N个 部门之间协同工作,公司搭建 ...
- 【BZOJ1146】网络管理(整体二分)
[BZOJ1146]网络管理(整体二分) 题面 良心洛谷,有BZOJ权限题 题解 要看树套树的戳这里 毕竟是:智商不够数据结构来补 所以, 我们来当一回智商够的选手 听说主席树的题目大部分都可以整体二 ...
- 【BZOJ1146】网络管理(主席树,树状数组)
[BZOJ1146]网络管理(主席树,树状数组) 题面 BZOJ权限题,洛谷题面 题解 树上带修改主席树 貌似和\(Count\ On\ A\ Tree\)那题很相似呀 只需要套上一个树状数组来维护修 ...
- 【BZOJ1146】[CTSC2008]网络管理Network 树状数组+DFS序+主席树
[BZOJ1146][CTSC2008]网络管理Network Description M公司是一个非常庞大的跨国公司,在许多国家都设有它的下属分支机构或部门.为了让分布在世界各地的N个部门之间协同工 ...
- 【BZOJ-1146】网络管理Network DFS序 + 带修主席树
1146: [CTSC2008]网络管理Network Time Limit: 50 Sec Memory Limit: 162 MBSubmit: 3495 Solved: 1032[Submi ...
- BZOJ1146 [CTSC2008]网络管理Network 树链剖分 主席树 树状数组
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1146 题意概括 在一棵树上,每一个点一个权值. 有两种操作: 1.单点修改 2.询问两点之间的树链 ...
- 【BZOJ1146】【CTSC2008】网络管理 [整体二分]
网络管理 Time Limit: 50 Sec Memory Limit: 162 MB[Submit][Status][Discuss] Description M公司是一个非常庞大的跨国公司,在 ...
- [BZOJ1146][CTSC2008]网络管理Network(二分+树链剖分+线段树套平衡树)
题意:树上单点修改,询问链上k大值. 思路: 1.DFS序+树状数组套主席树 首先按照套路,关于k大值的问题,肯定要上主席树,每个点维护一棵权值线段树记录它到根的信息. 关于询问,就是Que(u)+Q ...
- BZOJ1146——[CTSC2008]网络管理Network
1.题目大意:就是在动态的树上路径权值第k大. 2.分析:这个就是树链剖分+树套树 #include <cstdio> #include <cstdlib> #include ...
随机推荐
- 2021record
2021-10-14 P2577 [ZJOI2004]午餐 2021-10-13 CF815C Karen and Supermarket(小小紫题,可笑可笑) P6748 『MdOI R3』Fall ...
- MeteoInfo-Java解析与绘图教程(五)
MeteoInfo-Java解析与绘图教程(五) 最近太忙了,终于有时间继续写了,上文说到了基本上的绘图方法,但缺少色阶呈现,一般图叠加着地图上,后端不需要管色阶,但也要注意web页面色阶和我们的生成 ...
- 初识HTML02
HTML 超文本标记语言 什么是超文本标记语言 浏览器能够解释和解析的语言 通过元素的形式构建页面结构和填充内容 构建HTML页面 构建页面的步骤 创建一个扩展名为.html和.html的页面文件 向 ...
- 【c++ Prime 学习笔记】第9章 顺序容器
一个容器是特定类型对象的集合 顺序容器中元素的顺序与其加入容器的位置对应 关联容器中元素的顺序由其关联的关键字决定,关联容器分为有序关联容器和无序关联容器 所有容器类共享公有接口,不同容器按不同方式扩 ...
- Java:动态代理小记
Java:动态代理小记 对 Java 中的 动态代理,做一个微不足道的小小小小记 概述 动态代理:当想要给实现了某个接口的类中的方法,加一些额外的处理.比如说加日志,加事务等.可以给这个类创建一个代理 ...
- 机器学习:EM算法
EM算法 各类估计 最大似然估计 Maximum Likelihood Estimation,最大似然估计,即利用已知的样本结果,反推最有可能(最大概率)导致这样结果的参数值的计算过程. 直白来讲,就 ...
- Beta阶段第八次会议
Beta阶段第八次会议 时间:2020.5.24 完成工作 姓名 工作 难度 完成度 ltx 1.修改一下小程序游客模式的风格 轻 80% xyq 1.针对昨天提出的意见对场地申请表格进行修改 中 9 ...
- mysqld_exporter监控mysql信息
mysqld_exporter监控mysql信息 一.背景 二.prometheus接入mysqld_exporter 1.安装mysqld_exporter 2.创建mysqld_exporter用 ...
- mongodb的索引操作
在mongodb中,当我们一个集合中的数据量非常大时,比如几百万条数据,如果不使用索引,对数据的查询就会进行全表扫描,这个时候查询的速度就会非常的慢,此时我们就需要为集合建立上索引,从而加快查询的速度 ...
- 2021.6.17考试总结[NOIP模拟8]
T1 星际旅行 其实就是求两条只走一遍的边的方案数. 考场上第一眼就感觉不可做,后来画了几个图,发现好像只要两个边是相连的就可以只走一遍,居然还真拿了30.. 其实是一道欧拉路的题,把每条非自环的边看 ...