BZOJ 2588: Spoj 10628. Count on a tree [树上主席树]
2588: Spoj 10628. Count on a tree
Time Limit: 12 Sec Memory Limit: 128 MB
Submit: 5217 Solved: 1233
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
105 2 9 3 8 5 7 7
1 2
1 3
1 4
3 5
3 6
3 7
4 8
2 5 1
0 5 2
10 5 3
11 5 4
110 8 2
Sample Output
8
9
105
7
HINT
- #include<iostream>
- #include<cstdio>
- #include<cstring>
- #include<algorithm>
- using namespace std;
- typedef long long ll;
- const int N=1e5+,INF=1e9+;
- int read(){
- char c=getchar();int x=,f=;
- while(c<''||c>''){if(c=='-')f=-; c=getchar();}
- while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
- return x*f;
- }
- int n,Q,u,v,k,last,mp[N],m,w[N];
- struct ques{
- int u,v,k;
- }q[N];
- int Bin(int v){
- int l=,r=m;
- while(l<=r){
- int mid=(l+r)>>;
- if(mp[mid]==v) return mid;
- else if(v<mp[mid]) r=mid-;
- else l=mid+;
- }
- return -;
- }
- struct edge{
- int v,ne;
- }e[N<<];
- int h[N],cnt;
- inline void ins(int u,int v){
- cnt++;
- e[cnt].v=v;e[cnt].ne=h[u];h[u]=cnt;
- cnt++;
- e[cnt].v=u;e[cnt].ne=h[v];h[v]=cnt;
- }
- int size[N],fa[N],deep[N],mx[N],top[N],tid[N],tot;
- void dfs(int u){
- size[u]=;
- for(int i=h[u];i;i=e[i].ne){
- int v=e[i].v;
- if(v==fa[u]) continue;
- fa[v]=u;deep[v]=deep[u]+;
- dfs(v);
- size[u]+=size[v];
- if(size[mx[u]]<size[v]) mx[u]=v;
- }
- }
- void dfs(int u,int anc){
- if(!u) return;
- tid[u]=++tot;
- top[u]=anc;
- dfs(mx[u],anc);
- for(int i=h[u];i;i=e[i].ne){
- int v=e[i].v;
- if(v!=fa[u]&&v!=mx[u]) dfs(v,v);
- }
- }
- int lca(int x,int y){
- while(top[x]!=top[y]){
- if(deep[top[x]]<deep[top[y]]) swap(x,y);
- x=fa[top[x]];
- }
- if(tid[x]>tid[y]) swap(x,y);
- return x;
- }
- struct node{
- int l,r,size;
- }t[N*];
- int sz,root[N];
- void insert(int &x,int l,int r,int num){
- t[++sz]=t[x];x=sz;
- t[x].size++;
- if(l==r) return;
- int mid=(l+r)>>;
- if(num<=mid) insert(t[x].l,l,mid,num);
- else insert(t[x].r,mid+,r,num);
- }
- void build(int u){
- root[u]=root[fa[u]];
- insert(root[u],,m,Bin(w[u]));
- if(mx[u]) build(mx[u]);
- for(int i=h[u];i;i=e[i].ne)
- if(e[i].v!=fa[u]&&e[i].v!=mx[u]) build(e[i].v);
- }
- inline int ls(int x){return t[t[x].l].size;}
- int query(int u,int v,int k){
- int p=lca(u,v),q=fa[p];
- u=root[u];v=root[v];p=root[p];q=root[q];
- int l=,r=m;
- while(l!=r){
- int mid=(l+r)>>,_=ls(u)+ls(v)-ls(p)-ls(q);
- if(k<=_) r=mid,u=t[u].l,v=t[v].l,p=t[p].l,q=t[q].l;
- else l=mid+,u=t[u].r,v=t[v].r,p=t[p].r,q=t[q].r,k-=_;
- }
- return l;
- }
- int main(){
- n=read();Q=read();
- for(int i=;i<=n;i++) mp[i]=w[i]=read();
- for(int i=;i<=n-;i++) u=read(),v=read(),ins(u,v);
- dfs();dfs(,);
- for(int i=;i<=Q;i++) q[i].u=read(),q[i].v=read(),q[i].k=read();
- sort(mp+,mp++n);
- m=;
- for(int i=;i<=n;i++) if(mp[i]!=mp[i-]) mp[++m]=mp[i];
- build();
- for(int i=;i<=Q;i++){
- u=last^q[i].u;v=q[i].v;k=q[i].k;
- last=mp[query(u,v,k)];
- printf("%d",last);
- if(i!=Q) putchar('\n');
- }
- }
BZOJ 2588: Spoj 10628. Count on a tree [树上主席树]的更多相关文章
- BZOJ 2588: Spoj 10628. Count on a tree( LCA + 主席树 )
Orz..跑得还挺快的#10 自从会树链剖分后LCA就没写过倍增了... 这道题用可持久化线段树..点x的线段树表示ROOT到x的这条路径上的权值线段树 ----------------------- ...
- bzoj 2588 Spoj 10628. Count on a tree(主席树)
Description 给定一棵N个节点的树,每个点有一个权值,对于M个询问(u,v,k),你需要回答u xor lastans和v这两个节点间第K小的点权.其中lastans是上一个询问的答案,初始 ...
- bzoj 2588: Spoj 10628. Count on a tree【主席树+倍增】
算是板子,把值离散化,每个点到跟上做主席树,然后查询的时候主席树上用u+v-lca-fa[lca]的值二分 #include<iostream> #include<cstdio> ...
- BZOJ 2588: Spoj 10628. Count on a tree 树上跑主席树
2588: Spoj 10628. Count on a tree Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/J ...
- Bzoj 2588: Spoj 10628. Count on a tree 主席树,离散化,可持久,倍增LCA
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2588 2588: Spoj 10628. Count on a tree Time Limit ...
- Bzoj 2588 Spoj 10628. Count on a tree(树链剖分LCA+主席树)
2588: Spoj 10628. Count on a tree Time Limit: 12 Sec Memory Limit: 128 MB Description 给定一棵N个节点的树,每个点 ...
- BZOJ 2588: Spoj 10628. Count on a tree-可持久化线段树+LCA(点权)(树上的操作) 无语(为什么我的LCA的板子不对)
2588: Spoj 10628. Count on a tree Time Limit: 12 Sec Memory Limit: 128 MBSubmit: 9280 Solved: 2421 ...
- bzoj 2588 Spoj 10628. Count on a tree (可持久化线段树)
Spoj 10628. Count on a tree Time Limit: 12 Sec Memory Limit: 128 MBSubmit: 7669 Solved: 1894[Submi ...
- 主席树 || 可持久化线段树 || LCA || BZOJ 2588: Spoj 10628. Count on a tree || Luogu P2633 Count on a tree
题面: Count on a tree 题解: 主席树维护每个节点到根节点的权值出现次数,大体和主席树典型做法差不多,对于询问(X,Y),答案要计算ans(X)+ans(Y)-ans(LCA(X,Y) ...
随机推荐
- HTTP的长连接和短连接
本文总结&分享网络编程中涉及的长连接.短连接概念. 关键字:Keep-Alive,并发连接数限制,TCP,HTTP 一.什么是长连接 HTTP1.1规定了默认保持长连接(HTT ...
- Beginners Guide To Web Development
Web Development Front End Development Back End Development
- .NET MVC Razor模板预编译(二)
在前面一片文章:<.NET MVC4 Razor视图预编译(一)> 里面我采用的是PrecompiledMvcViewEngineContrib组件进行预编译视图的虚拟地址注册,但是这个组 ...
- CRL2.3(ORM开发框架)源码github发布
简介 CRL是一个面向对象的轻便型ORM业务框架 此框架追求的是使用简单,方便,因此设计为: 不需要代码生成器生成对象类,按标准方式写即可 依托lambda,实现语法解析转换为等效的SQL查询,完全以 ...
- 打造android偷懒神器———ListView的万能适配器
如果你去做任何一个项目,我相信你都会跟我有一样的经历,最最普遍的就是列表显示ListView,当然,写N个自定义的适配器也是情理之中.虽说程序员本身就是搬砖,做这些枯燥无味的重复的事情也是理所当然,但 ...
- CSS3属性 box-shadow 向框添加一个或多个阴影
CSS3属性 利用box-shadow制作网页页眉背景 box-shadow 浏览器支持 IE9+.Firefox 4.Chrome.Opera 以及 Safari 5.1.1 支持 box-shad ...
- Ionic2系列——使用DeepLinker实现指定页面URL
Ionic2使用了近似原生App的页面导航方式,并不支持Angular2的路由.这种方式在开发本地App的时候比较方便,但如果要用来开发纯Web页面就有点问题了,这种情况下Angular2的route ...
- [C1] 优化 C1FlexGrid 单元格边框
一 优化理由 如下图所示,如果按照 C1FlexGrid 自带的单元格边框设置,即对每个单元格的 CellStyle 的 BorderThickness 进行设置,会得到如下图的效果: 其中,明显可 ...
- Linux下安装Hadoop完全分布式(Ubuntu12.10)
Hadoop的安装非常简单,可以在官网上下载到最近的几个版本,最好使用稳定版.本例在3台机器集群安装.hadoop版本如下: 工具/原料 hadoop-0.20.2.tar.gz Ubuntu12.1 ...
- 最小生成树计数 bzoj 1016
最小生成树计数 (1s 128M) award [问题描述] 现在给出了一个简单无向加权图.你不满足于求出这个图的最小生成树,而希望知道这个图中有多少个不同的最小生成树.(如果两颗最小生成树中至少有一 ...