[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 ...
随机推荐
- 初步认识HCIA,什么是计算机网络,拓扑,网络的发展,交换机,路由器,IP,光纤,带宽,广播,ARP......
HCIA ---- 华为认证初级网络工程师 云技术 --- 云存储 云计算 计算机技术 : --- 抽象语言 -- 电线号的转换 抽象语言 -- 编码 ---- 应用层 编码 --- 二进制 -- ...
- CQOI2021 退役记
Day -1 晚上去了酒店然后就睡觉了. Day 1 进考场之前互相奶. 进了考场之后看题,发现T1很水(伏笔1,然后直接开始写 \(\Theta(n\log^2n)\)(二分+动态开点线段树),调了 ...
- 题解 [HNOI2016]大数
题目传送门 题目大意 给出一个\(n\)个数的字符串,有\(m\)次查询,对于该串的子串\([l,r]\)有多少个子串满足是固定素数\(p\)的倍数. 思路 其实很简单,但是一开始想偏了...果然还是 ...
- LuckySheet一款在线Excel使用心得
1.LuckySheet简介 Luckysheet ,是一款国产的纯JS实现的类似excel的在线表格,功能强大.配置简单.完全开源. 开源地址 https://gitee.com/mengshuke ...
- NX开发库版本问题
有做NX二次开发的朋友经常问我这样的问题:我在NX8.0上开发的程序,可以在NX9.0上运行吗? 由于NX的开发库随着版本的更新也会不断更新,会增加新的方法,同时有些也会过时或者消失. 如下图:NX8 ...
- Flink sql 之 join 与 StreamPhysicalJoinRule (源码解析)
源码分析基于flink1.14 Join是flink中最常用的操作之一,但是如果滥用的话会有很多的性能问题,了解一下Flink源码的实现原理是非常有必要的 本文的join主要是指flink sql的R ...
- Beta阶段第四次会议
Beta阶段第四次会议 时间:2020.5.20 完成工作 姓名 工作 难度 完成度 ltx 1.对小程序进行修改2.提出相关api修改要求 轻 85% xyq 1.设计所需api文档2.编写相关技术 ...
- centOs7.6安装 mysql-8.0.27
1.下载mysql 2.连接服务器 3.通过 rpm -qa | grep mariadb 命令查看 mariadb 的安装包 4.通过 rpm -e mariadb-libs-5.5.68-1.el ...
- 2021.10.7考试总结[NOIP模拟71]
信心赛,但炸了.T3SB错直接炸飞,T4可以硬算的组合数非要分段打表求阶乘..T2也因为一个细节浪费了大量时间.. 会做难题很好,但首先还是要先把能拿的分都拿到. T1 签到题 结论:总可以做到对每个 ...
- Go语言核心36讲(Go语言进阶技术九)--学习笔记
15 | 关于指针的有限操作 在前面的文章中,我们已经提到过很多次"指针"了,你应该已经比较熟悉了.不过,我们那时大多指的是指针类型及其对应的指针值,今天我们讲的则是更为深入的内容 ...