搞出dfs序,转化为查询矩形点数,树套树搞定。

#include<cstdio>
#include<cstdlib>
#define N 100005
#define IF else if
struct edge{
edge*s;
int v;
}
z[N*2],*next=z,*h[N];
int n,m,q;
void add(int u,int v){
h[u]=&(*next++=(edge){
h[u],v
}
);
h[v]=&(*next++=(edge){
h[v],u
}
);
}
typedef int ds[N];
ds d,p,r,l,son,y;
void dfs1(int u){
r[u]=1;
d[u]=d[p[u]]+1;
int s=0;
for(edge*i=h[u];i;i=i->s)
if(i->v!=p[u]){
p[i->v]=u;
dfs1(i->v);
r[u]+=r[i->v];
if(s<r[i->v])
s=r[son[u]=i->v];
}
}
void dfs2(int u){
static int j;
l[u]=++j;
if(r[u]!=1){
y[son[u]]=y[u];
dfs2(son[u]);
}
for(edge*i=h[u];i;i=i->s)
if(i->v!=p[u]&&i->v!=son[u])
dfs2(y[i->v]=i->v);
}
int lca(int s,int t){
while(y[s]^y[t])
d[y[s]]<d[y[t]]?(s^=t,t^=s,s^=t):0,s=p[y[s]];
return d[s]<d[t]?s:t;
}
struct node{
int v,s,a,q;
node*l,*r;
void up(){
s=l->s+r->s+a;
}
}
*f[N],e[N*40];
node*back=e+1;
node*create(int v){
return&(*back++=(node){
v,1,1,rand(),e,e
}
);
}
void lturn(node*&s){
node*a=s->r;
s->r=a->l;
s->up(),a->l=s;
a->up(),s=a;
}
void rturn(node*&s){
node*a=s->l;
s->l=a->r;
s->up(),a->r=s;
a->up(),s=a;
}
void ins(int v,node*&s){
if(!s->s)
s=create(v);
IF(v==s->v)++s->a,s->up();
IF(v<s->v){
ins(v,s->l);
if(s->l->q>s->q)
rturn(s);
else s->up();
}
else{
ins(v,s->r);
if(s->r->q>s->q)
lturn(s);
else s->up();
}
}
void del(int v,node*&s){
if(v<s->v)
del(v,s->l),s->up();
IF(s->v<v)del(v,s->r),s->up();
IF(s->a>1)--s->a,s->up();
IF(s->l==e)s=s->r;
IF(s->r==e)s=s->l;
IF(s->l->q>s->r->q)rturn(s),del(v,s->r),s->up();
else lturn(s),del(v,s->l),s->up();
}
int query(int v,node*s){
int k=0;
for(;;s=s->r){
while(s->s&&v<s->v)
s=s->l;
if(!s->s)
break;
k+=s->l->s+s->a;
}
return k;
}
int query(int i,int j){
for(int k=0;;i^=i&-i){
if(!i)
return k;
k+=query(j,f[i]);
}
}
void ins1(int i,int j){
for(;i<=n;i+=i&-i)
ins(j,f[i]);
}
void ins2(int s,int t){
if(l[s]<l[t])
s^=t,t^=s,s^=t;
ins1(l[t],l[s]);
}
void del1(int i,int j){
for(;i<=n;i+=i&-i)
del(j,f[i]);
}
void del2(int s,int t){
if(l[s]<l[t])
s^=t,t^=s,s^=t;
del1(l[t],l[s]);
}
int query(int i,int j,int s,int t){
return query(j,t)-query(j,s-1)-query(i-1,t)+query(i-1,s-1);
}
int find(int s,int t){
static int j;
for(;y[s]^y[t];s=p[j])
j=y[s];
return s^t?son[t]:j;
}
int qtree(int s,int t){
if(d[s]<d[t])
s^=t,t^=s,s^=t;
static int i,j,k;
i=l[s],j=l[s]+r[s]-1;
if(lca(s,t)!=t)
return l[s]<l[t]?query(i,j,l[t],l[t]+r[t]-1):query(l[t],l[t]+r[t]-1,i,j);
k=find(s,t);
return(l[k]+r[k]>n?0:query(i,j,l[k]+r[k],n))+query(1,l[k]-1,i,j);
}
int main(){
struct{
operator int(){
int x;
scanf("%d",&x);
return x;
}
}
it;
n=it;
for(int i=0;i<=n;++i)
f[i]=e;
for(int i=1;i!=n;++i)
add(it,it);
dfs1(1),dfs2(y[1]=1);
for(m=it;m;--m)
ins2(it,it);
for(q=it;q;--q){
int k=it,s=it,t=it;
if(k==3)
printf("%d\n",qtree(s,t));
if(k==1)
ins2(s,t);
if(k==2)
del2(s,t);
}
}

BZOJ4285: 使者的更多相关文章

  1. 【BZOJ4285】使者 cdq分治+扫描线+树状数组

    [BZOJ4285]使者 Description 公元 8192 年,人类进入星际大航海时代.在不懈的努力之下,人类占领了宇宙中的 n 个行星,并在这些行星之间修建了 n - 1 条星际航道,使得任意 ...

  2. BZOJ 4285 使者

    我TM再也不写BIT套主席树了.... #include<iostream> #include<cstdio> #include<cstring> #include ...

  3. 伟大的通信使者——JSON(JavaScript版本)

    JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式.它基于 ECMAScript 规范的一个子集,采用完全独立于编程语言的文本格式来存储和表 ...

  4. BZOJ 4285 使者 (CDQ分治+dfs序)

    题目传送门 题目大意:给你一棵树,有三种操作,在两个点之间连一个传送门,拆毁一个已有的传送门,询问两个点之间的合法路径数量.一条合法路径满足 1.经过且仅经过一个传送门 2.不经过起点终点简单路径上的 ...

  5. Android 面试题--Service

    1.Service 是否在 main thread 中执行, service 里面是否能执行耗时的操作?默认情况,如果没有显示的指 servic 所运行的进程, Service 和 activity ...

  6. C语言 关于内存动态分配问题

    全局变量:分配到 内存的静态区. 局部变量(非静态):分配到 内存的动态区.在存储区中称为栈(stack) 临时数据(C允许内存动态分配区域):存放在自由空间区,称为堆区(heap) 内存动态分配 得 ...

  7. HTML5 WebSocket

    在WebSocket API中,浏览器和服务器只需要做一个握手动作,然后,浏览器和服务器之间就形成一条快速通道,两者之间就可以直接进行数据传送,这一个功能可以应用到"字幕",自己做 ...

  8. Atitit.自然语言处理--摘要算法---圣经章节旧约39卷概览bible overview v2 qa1.docx

    Atitit.自然语言处理--摘要算法---圣经章节旧约39卷概览bible overview v2 qa1.docx 1. 摘要算法的大概流程2 2. 旧约圣经 (39卷)2 2.1. 与古兰经的对 ...

  9. React.js入门笔记

    # React.js入门笔记 核心提示 这是本人学习react.js的第一篇入门笔记,估计也会是该系列涵盖内容最多的笔记,主要内容来自英文官方文档的快速上手部分和阮一峰博客教程.当然,还有我自己尝试的 ...

随机推荐

  1. RHEL 5.7 Yum配置本地源[Errno 2] No such file or directory

    在Red Hat Enterprise Linux Server release 5.7 上配置YUM本地源时,遇到了"Errno 5] OSError: [Errno 2] No such ...

  2. 0027 Java学习笔记-面向对象-(非静态、静态、局部、匿名)内部类

    内部类 内部类就是把一个类写在另一个类的内部 用途: 如果一个类只希望它被某一个类访问,那么可以把它定义在另一个类的内部,并用private修饰 内部类可以访问它所在外部类的private成员:但所在 ...

  3. SQL Server自动化运维系列——关于数据收集(多服务器数据收集和性能监控)

    需求描述 在生产环境中,很多情况下需要采集数据,用以定位问题或者形成基线. 关于SQL Server中的数据采集有着很多种的解决思路,可以采用Trace.Profile.SQLdiag.扩展事件等诸多 ...

  4. OAF通过Iterator标准遍历各行

    这两天本人接到客户反映的bug:oaf的采购订单页面,在添加超过10行提交后,会出现空指针异常.原来,oaf的默认显示行数为10行,超过10行,页面会分页.报空指针异常,就是因为没有取到分页的行.之前 ...

  5. Live Migrate 操作 - 每天5分钟玩转 OpenStack(42)

    Migrate 操作会先将 instance 停掉,也就是所谓的“冷迁移”.而 Live Migrate 是“热迁移”,也叫“在线迁移”,instance不会停机. Live Migrate 分两种: ...

  6. logback配置详解1

    一:根节点<configuration>包含的属性: scan: 当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true. scanPeriod: 设置监测配置文 ...

  7. php使用curl 检测socks5 代理的可用性

    少废话  直接粘代码 <?php    define('PROXY_CONF', 'ip:port');    define('PROXY_CHECK_URL', 'http://www.bai ...

  8. UVA计数方法练习[3]

    UVA - 11538 Chess Queen 题意:n*m放置两个互相攻击的后的方案数 分开讨论行 列 两条对角线 一个求和式 可以化简后计算 // // main.cpp // uva11538 ...

  9. NYOJ 70

    描述:给定两个数n,m,其中m是一个素数. 将n(0<=n<=2^31)的阶乘分解质因数,求其中有多少个m. 注:^为求幂符号. 输入: 第一行是一个整数s(0<s<=100) ...

  10. C程序运行计时

    在标准的C/C++中最小的时间单位是毫秒ms,下面代码中clock_t是long: 每经过1ms clock()的值就增加1:常量CLOCKS_PER_SEC,它用来表示一秒钟会有多少个时钟计时单元 ...