发现是链上的问题,所以树链剖分
发现要查询第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]网络管理的更多相关文章

  1. [BZOJ1146][CTSC2008]网络管理Network

    [BZOJ1146][CTSC2008]网络管理Network 试题描述 M公司是一个非常庞大的跨国公司,在许多国家都设有它的下属分支机构或部门.为了让分布在世界各地的N个 部门之间协同工作,公司搭建 ...

  2. 【BZOJ1146】网络管理(整体二分)

    [BZOJ1146]网络管理(整体二分) 题面 良心洛谷,有BZOJ权限题 题解 要看树套树的戳这里 毕竟是:智商不够数据结构来补 所以, 我们来当一回智商够的选手 听说主席树的题目大部分都可以整体二 ...

  3. 【BZOJ1146】网络管理(主席树,树状数组)

    [BZOJ1146]网络管理(主席树,树状数组) 题面 BZOJ权限题,洛谷题面 题解 树上带修改主席树 貌似和\(Count\ On\ A\ Tree\)那题很相似呀 只需要套上一个树状数组来维护修 ...

  4. 【BZOJ1146】[CTSC2008]网络管理Network 树状数组+DFS序+主席树

    [BZOJ1146][CTSC2008]网络管理Network Description M公司是一个非常庞大的跨国公司,在许多国家都设有它的下属分支机构或部门.为了让分布在世界各地的N个部门之间协同工 ...

  5. 【BZOJ-1146】网络管理Network DFS序 + 带修主席树

    1146: [CTSC2008]网络管理Network Time Limit: 50 Sec  Memory Limit: 162 MBSubmit: 3495  Solved: 1032[Submi ...

  6. BZOJ1146 [CTSC2008]网络管理Network 树链剖分 主席树 树状数组

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1146 题意概括 在一棵树上,每一个点一个权值. 有两种操作: 1.单点修改 2.询问两点之间的树链 ...

  7. 【BZOJ1146】【CTSC2008】网络管理 [整体二分]

    网络管理 Time Limit: 50 Sec  Memory Limit: 162 MB[Submit][Status][Discuss] Description M公司是一个非常庞大的跨国公司,在 ...

  8. [BZOJ1146][CTSC2008]网络管理Network(二分+树链剖分+线段树套平衡树)

    题意:树上单点修改,询问链上k大值. 思路: 1.DFS序+树状数组套主席树 首先按照套路,关于k大值的问题,肯定要上主席树,每个点维护一棵权值线段树记录它到根的信息. 关于询问,就是Que(u)+Q ...

  9. BZOJ1146——[CTSC2008]网络管理Network

    1.题目大意:就是在动态的树上路径权值第k大. 2.分析:这个就是树链剖分+树套树 #include <cstdio> #include <cstdlib> #include ...

随机推荐

  1. JVM学习笔记——GC垃圾收集器

    GC 垃圾收集器 Java 堆内存采用分代回收算法,因此 JVM 针对新生代和老年代提供了多种垃圾收集器. 1. Serial 收集器 Serial 收集器是单线程收集器,采用复制算法. 是最基本的垃 ...

  2. 395.至少有 K 个重复字符的最长子串

    题目 给你一个字符串 s 和一个整数 k ,请你找出 s 中的最长子串, 要求该子串中的每一字符出现次数都不少于k .返回这一子串的长度. 示例 1: 输入:s = "aaabb" ...

  3. pycharm中的terminal和Windows命令提示符有什么区别?二者用pip安装的包是不是位于相同位置?

    那要看pycharm使用了什么shell,可以在设置->工具->终端里查看shell path.如果使用的是cmd.exe那就没区别.pycharm终端和Windows命令提示符用pip安 ...

  4. 【二食堂】Beta - Scrum Meeting 2

    Scrum Meeting 2 例会时间:5.14 18:30~18:50 进度情况 组员 当前进度 今日任务 李健 1. 还在进行摸索,目前做出了一个demo可以进行简单的划词 issue 1. 继 ...

  5. 用cmd命令行创建vue项目模板

    1.进入cmd命令行 输入存放项目的位置 2.通过vue create 项目名称 创建项目 3.选择Manually select features 4.通过空格选中第1.2.5.6.7.去掉8 4. ...

  6. 如何清理history

    工作中,需要清理history 清理当前会话历史命令    history -c 清理当前用户所有历史命令     echo > .bash_history     #在用户主目录执行此操作

  7. RocketMQ源码详解 | Broker篇 · 其一:线程模型与接收链路

    概述 在上一节 RocketMQ源码详解 | Producer篇 · 其二:消息组成.发送链路 中,我们终于将消息发送出了 Producer,在短暂的 tcp 握手后,很快它就会进入目的 Broker ...

  8. CPU使用率和平均负载

    转载: https://mp.weixin.qq.com/s?__biz=MzU4NzU0MDIzOQ==&mid=2247487782&idx=3&sn=3f04bb053d ...

  9. 斐波那契数列 牛客网 剑指Offer

    斐波那契数列 牛客网 剑指Offer 题目描述 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0). n<=39 class Solution: ...

  10. 重建二叉树 牛客网 剑指Offer

    重建二叉树 牛客网 剑指Offer 题目描述 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3, ...