复制的树缩点,主席树查k小,毫无技术含量,纯码农题。

#include<bits/stdc++.h>
#define u first
#define v second
#define F lower_bound
#define I (i+j+2>>1)
#define J (i+j>>1)
using namespace std;
int n1,n2,m,n4;
typedef long long ll;
map<ll,int>nu;
const int N=1e5+5;
struct edge{
int v;edge*s;
}z[N*2];
edge*a=z,*h[N];
void ins(int u,int v){
edge s={v,h[u]};
*(h[u]=a++)=s;
}
typedef int arr[N];
arr l,r,b,po,id,d[2],p[2][17];
ll n3,u,v,c[N];
void dfs(int u){
r[id[l[u]=++n4]=u]=1;
for(edge*i=h[u];i;i=i->s)
if(i->v^p[0][0][u]){
d[0][i->v]=d[0][p[0][0][i->v]=u]+1;
dfs(i->v);
r[u]+=r[i->v];
}
}
typedef struct node*ptr;
struct node{
ptr i,j;int s;
}e[N][17];
void ins(int i,int j,int s,ptr u,ptr v){
while(i<j){
*v=*u;
if(s>J)u=u->j,v=v->j=v+1,i=J+1;
else
++v->s,u=u->i,v=v->i=v+1,j=I-1;
}
}
int ask(int i,int j,int k,ptr u,ptr v){
while(i<j){
int s=v->s-u->s;
if(k<=s)u=u->i,v=v->i,j=I-1;
else
k-=s,u=u->j,v=v->j,i=J+1;
}
return i;
}
int lca(int i,int s,int t){
if(d[i][s]<d[i][t])swap(s,t);
int k=d[i][s]-d[i][t];
for(int j=16;~j;--j)
if(k>>j&1)s=p[i][j][s];
if(s==t)return s;
for(int j=16;~j;--j)
if(p[i][j][s]^p[i][j][t])
s=p[i][j][s],t=p[i][j][t];
return p[i][0][s];
}
typedef pair<int,int>vec;
typedef pair<vec,int>tri;
tri ask(ll v){
typeof(nu.end())j=nu.F(v);
int s=po[j->v];
return tri(vec(ask(1,n1,v-j->u+r[s],e[l[s]-1],e[l[s]+r[s]-1]),s),j->v);
}
int ask(int s,int k){
for(int j=16;~j;--j)
if(k>>j&1)s=p[1][j][s];
return s;
}
int main(){
scanf("%d%d%d",&n1,&n2,&m),++n2;
for(int i=2;i<=n1;++i)
scanf("%lld%lld",&u,&v),ins(u,v),ins(v,u);
dfs(po[nu[n3=n1]=1]=1);
e[0][0]=(node){e[0],e[0]};
for(int i=1;i<=n1;++i)
ins(1,n1,id[i],e[i-1],e[i]);
for(int i=2;i<=n2;++i){
scanf("%lld%lld",&u,&v);
tri s=ask(v);
d[1][i]=d[1][p[1][0][i]=s.v]+1,c[i]=c[s.v]+d[0][b[i]=s.u.u]-d[0][s.u.v]+1,po[nu[n3+=r[u]]=i]=u;
}
for(int i=1;i<17;++i){
for(int j=1;j<=n1;++j)
p[0][i][j]=p[0][i-1][p[0][i-1][j]];
for(int j=2;j<=n2;++j)
p[1][i][j]=p[1][i-1][p[1][i-1][j]];
}
while(m--){
scanf("%lld%lld",&u,&v);
tri s1=ask(u),t1=ask(v);
int l1=lca(1,s1.v,t1.v);
int s2=s1.u.u,t2=t1.u.u;
ll l3=0;
if(s1.v^l1){
int s3=ask(s1.v,d[1][s1.v]-d[1][l1]-1);
l3+=d[0][s2]-d[0][s1.u.v]+c[s1.v]-c[s3]+1,s2=b[s3];
}
if(t1.v^l1){
int t3=ask(t1.v,d[1][t1.v]-d[1][l1]-1);
l3+=d[0][t2]-d[0][t1.u.v]+c[t1.v]-c[t3]+1,t2=b[t3];
}
int l2=lca(0,s2,t2);
l3+=d[0][s2]+d[0][t2]-d[0][l2]*2;
printf("%lld\n",l3);
}
}

BZOJ4539: [Hnoi2016]树的更多相关文章

  1. [BZOJ4539][HNOI2016]树(主席树)

    4539: [Hnoi2016]树 Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 746  Solved: 292[Submit][Status][D ...

  2. BZOJ4539 [Hnoi2016]树 【倍增 + 主席树】

    题目链接 BZOJ4539 题解 我们把每次复制出来的树看做一个点,那么大树实际上也就是一棵\(O(M)\)个点的树 所以我们只需求两遍树上距离: 大树上求距离,进入同一个点后在模板树上再求一次距离 ...

  3. 2019.03.25 bzoj4539: [Hnoi2016]树(主席树+倍增)

    传送门 题意:给一棵大树,令一棵模板树与这棵树相同,然后进行mmm次操作,每次选择模板树中的一个节点aaa和大树中一个节点bbb,把aaa这棵子树接在bbb上面,节点编号顺序跟aaa中的编号顺序相同. ...

  4. BZOJ 4539: [Hnoi2016]树 [主席树 lca]

    4539: [Hnoi2016]树 题意:不想写.复制模板树的子树,查询两点间距离. *** 终于有一道会做的题了...... 画一画发现可以把每次复制的子树看成一个大点来建一棵树,两点的lca一定在 ...

  5. 【LG3248】[HNOI2016]树

    [LG3248][HNOI2016]树 题面 洛谷 题解 因为每次你加入的点是原树上某一棵子树 那么我们一次加入一个点,代表一棵子树加到大树下面 那么我们要找到一个点在一个大点中用主席树在\(dfs\ ...

  6. 4539: [Hnoi2016]树

    4539: [Hnoi2016]树 链接 分析: 主席树+倍增. 代码: #include<cstdio> #include<algorithm> #include<cs ...

  7. [HNOI2016]树(可持久化线段树+树上倍增)

    [HNOI2016]树(可持久化线段树+树上倍增) 题面 给出一棵n个点的模板树和大树,根为1,初始的时候大树和模板树相同.接下来操作m次,每次从模板树里取出一棵子树,把它作为新树里节点y的儿子.操作 ...

  8. bzoj 4539: [Hnoi2016]树

    Description 小A想做一棵很大的树,但是他手上的材料有限,只好用点小技巧了.开始,小A只有一棵结点数为N的树,结 点的编号为1,2,-,N,其中结点1为根:我们称这颗树为模板树.小A决定通过 ...

  9. [HNOI2016]树

    Description 小A想做一棵很大的树,但是他手上的材料有限,只好用点小技巧了.开始,小A只有一棵结点数为N的树,结 点的编号为1,2,…,N,其中结点1为根:我们称这颗树为模板树.小A决定通过 ...

随机推荐

  1. Oracle研究专题:Oracle系统安装与配置

    最近开始研究Oracle数据库,盖因公司的系统要么Oracle要么是mysql吧. 作为一个IT工作者,没有碰过Oracle是一件很匪夷所思得事情. 想到过去几年,乃至接触IT行业开始就只有玩过sql ...

  2. VS2012 Unit Test——Microsoft Fakes入门

    如题,本文主要作为在VS2012使用Fakes的入门示例,开发工具必须是VS2012或更高版本. 关于Fakes的MSDN地址:http://msdn.microsoft.com/en-us/libr ...

  3. A new comer playing with Raspberry Pi 3B

    there are some things to do for raspberry pi 3b for the first time: 1, connect pi with monitor/KB/mo ...

  4. 分享一下Java写的坦克大战游戏,相信很多人小时候玩过

    写在前面 程序是五六年前读书的时候写的,里面会有一些不规范的,我已经将代码传到github上了,有时间会优化修改. 程序运行机制 定义了一个JPanel,然后每隔一小段时间重绘一遍. 重绘的内容如下: ...

  5. 数据库设计范式2——BC范式和第四范式

    我在很久之前的一篇文章中介绍了数据库模型设计中的基本三范式,今天,我来说一说更高级的BC范式和第四范式. 回顾 我用大白话来回顾一下什么是三范式: 第一范式:每个表应该有唯一标识每一行的主键. 第二范 ...

  6. Debain下解决sublime无法输入中文

    sublime安装的方法在此不做过多介绍,网上有很多中教程的方式.本文描述在已经安装sublime的前提下如何输入中文. 1.保存下面的代码到文件sublime_imfix.c(位于~目录) #inc ...

  7. Spark概述

    背景 目前按照大数据处理类型来分大致可以分为:批量数据处理.交互式数据查询.实时数据流处理,这三种数据处理方式对应的业务场景也都不一样: 关注大数据处理的应该都知道Hadoop,而Hadoop的核心为 ...

  8. NRF24L01 无线模块的使用

    NRF24L01 是一款工作在2.4-2.5GHz通用ISM频段的单片收发芯片 工作电压:1.9-3.6V低电压工作 高速率:2Mbps,由于空中传输时间很短,极大的降低了无线传输中的碰撞现象 多频点 ...

  9. monkeyrunner之控件ID不存在或重复

    我们在用monkeyrunner进行Android自动化时,通过获取坐标点或控件ID进行一系列操作.由于使用坐标点时,屏幕分辨率一旦更改,则代码中用到坐标的地方都要修改,这样导致代码的复用率较低.因此 ...

  10. [.NET逆向] 破解NET的四大神器

     原本这篇文章可以更早一星期写出来与大家分享,由于某方面的原因耽搁到现在,心里竟有那么一点好像对不住大家的感觉.这当然与神器有关,因为我发现利用这四大神器我似乎觉得几乎所有的NET程序破解都不在话下了 ...