话说我可能还没有调出魔法森林呢。。。说好的lct第一题呢。。。

又是一个随机化的方法,毕竟又是判定性的问题

上次是判断无向图联通

这次是判断一些路径是否经过一条定边

若把路径上的边全部异或上一个路径的权值

只要判断这条边的权值是否是所有路径的权值异或和就没了

lct维护链上异或和就好了

 #include<bits/stdc++.h>
#define MAXN 100010
#define MAXM 300010
#define ll long long
using namespace std;
int fa[MAXN],son[MAXN][],siz[MAXN],pe[MAXN],ne[MAXN],fe[MAXN],le[MAXN],sum[MAXN],ch[MAXN];
int val[MAXN+MAXM];
bool rev[MAXN];
int st[MAXN],tp;
int v[MAXM],v1[MAXM],v2[MAXM],cnt;
int n,m;
int S;
int tot;
int rd()
{
if(RAND_MAX==) return (rand()<<)+rand();
else return rand();
}
bool ir(int x)
{
return son[fa[x]][]!=x&&son[fa[x]][]!=x;
}
void ud(int x)
{
siz[x]=siz[son[x][]]+siz[son[x][]]+;
sum[x]=;
fe[x]=pe[x];
le[x]=ne[x];
if(son[x][])
{
sum[x]^=sum[son[x][]]^val[pe[x]];
fe[x]=fe[son[x][]];
}
if(son[x][])
{
sum[x]^=sum[son[x][]]^val[ne[x]];
le[x]=le[son[x][]];
}
}
void torev(int x)
{
if(!x)
return;
swap(son[x][],son[x][]);
swap(pe[x],ne[x]);
swap(fe[x],le[x]);
rev[x]^=;
}
void toch(int x,int y)
{
if(!x)
return;
if(siz[x]&^)
sum[x]^=y;
if(son[x][])
val[pe[x]]^=y;
if(son[x][])
val[ne[x]]^=y;
ch[x]^=y;
}
void pd(int x)
{
if(rev[x])
{
torev(son[x][]);
torev(son[x][]);
rev[x]=;
}
if(ch[x])
{
toch(son[x][],ch[x]);
toch(son[x][],ch[x]);
ch[x]=;
}
}
void cot(int x,int y,int z)
{
if(x)
fa[x]=y;
if(y)
son[y][z]=x;
}
void rot(int x,bool z)
{
int xx=fa[x],xxx=fa[xx];
cot(son[x][z],xx,z^);
if(ir(xx))
fa[x]=xxx;
else
cot(x,xxx,son[xxx][]==xx);
cot(xx,x,z);
ud(xx);
}
void apd(int x)
{
int i;
st[++tp]=x;
for(i=x;!ir(i);i=fa[i])
st[++tp]=fa[i];
for(;tp;tp--)
pd(st[tp]);
}
void splay(int x)
{
apd(x);
while(!ir(x))
{
int xx=fa[x],xxx=fa[xx];
if(ir(xx))
rot(x,son[xx][]==x);
else
{
bool z=son[xxx][]==xx;
if(son[xx][z]==x)
{
rot(x,z^);
rot(x,z);
}
else
{
rot(xx,z);
rot(x,z);
}
}
}
ud(x);
}
void acs(int x)
{
int t=;
while(x)
{
splay(x);
son[x][]=t;
ne[x]=fe[t];
ud(x);
t=x;
x=fa[x];
}
}
void reboot(int x)
{
acs(x);
splay(x);
torev(x);
}
void link(int x,int y,int z)
{
reboot(x);
fa[x]=y;
pe[x]=z;
}
void pick(int x,int y)
{
reboot(y);
acs(x);
splay(x);
}
void cut(int x,int y)
{
pick(x,y);
son[x][]=fa[y]=;
pe[x]=fe[x]=ne[y]=le[y]=;
ud(x);
ud(y);
}
int ask(int x,int y)
{
pick(x,y);
return sum[x];
}
void change(int x,int y,int z)
{
pick(x,y);
toch(x,z);
}
int main()
{
int i,o,x,y,z,xx,yy;
srand(time());
scanf("%*d%d%d",&n,&m);
for(i=;i<=n;i++)
siz[i]=;
for(i=;i<n;i++)
{
scanf("%d%d",&x,&y);
link(x,y,++tot);
}
while(m--)
{
int cmd;
scanf("%d",&cmd);
if(cmd==)
{
scanf("%d%d%d%d",&x,&y,&xx,&yy);
z=ask(x,y);
cut(x,y);
link(xx,yy,++tot);
change(x,y,z);
}
if(cmd==)
{
cnt++;
scanf("%d%d",&v1[cnt],&v2[cnt]);
v[cnt]=rd();
S^=v[cnt];
change(v1[cnt],v2[cnt],v[cnt]);
}
if(cmd==)
scanf("%d",&x),
S^=v[x],
change(v1[x],v2[x],v[x]);
if(cmd==)
scanf("%d%d",&x,&y),
puts(ask(x,y)==S?"YES":"NO");
}
return ;
}

uoj207共价大爷游长沙的更多相关文章

  1. [UOJ207]共价大爷游长沙

    UOJ sol 这题真是太神啦! 对于S集合中的每个点对,给他们随机附上一个相同权值. 两个点在边(x,y)的两侧当且仅当一个点在x的子树中,另一个点不在x的子树中(假设x是y的儿子) 维护一下子树点 ...

  2. uoj207 共价大爷游长沙 子树信息 LCT + 随机化 + 路径覆盖

    题目传送门 http://uoj.ac/problem/207 题解 如果是一棵静态的树,有一个非常容易想到的算法:统计一下目前的每一个条边被几条路径经过,如果 \(x\) 到 \(y\) 的边的这个 ...

  3. 【LCT维护子树信息】uoj207 共价大爷游长沙

    这道题思路方面就不多讲了,主要是通过这题学一下lct维护子树信息. lct某节点u的子树信息由其重链的一棵splay上信息和若干轻儿子子树信息合并而成. splay是有子树结构的,可以在rotate, ...

  4. 【UOJ207】共价大爷游长沙(Link-Cut Tree,随机化)

    [UOJ207]共价大爷游长沙(Link-Cut Tree,随机化) 题面 UOJ 题解 这题太神了 \(\%\%\%myy\) 看到动态的维护边很容易的想到了\(LCT\) 然后能否堵住一条路 我们 ...

  5. 「UOJ207」共价大爷游长沙

    「UOJ207」共价大爷游长沙 解题思路 : 快速判断两个集合是否完全相等可以随机点权 \(\text{xor}\) 的思路可以用到这道题上面,给每一条路径随机一个点权,维护出经过每一条边的点权的 \ ...

  6. UOJ #207. 共价大爷游长沙 [lct 异或]

    #207. 共价大爷游长沙 题意:一棵树,支持加边删边,加入点对,删除点对,询问所有点对是否经过一条边 一开始一直想在边权上做文章,或者从连通分量角度考虑,比较接近正解了,但是没想到给点对分配权值所以 ...

  7. 【刷题】UOJ #207 共价大爷游长沙

    火车司机出秦川,跳蚤国王下江南,共价大爷游长沙.每个周末,勤劳的共价大爷都会开车游历长沙市. 长沙市的交通线路可以抽象成为一个 \(n\) 个点 \(n−1\) 条边的无向图,点编号为 \(1\) 到 ...

  8. UOJ #207. 共价大爷游长沙

    #207. 共价大爷游长沙 链接:http://uoj.ac/problem/207 题意:给一棵树,要求支持加边.删边.询问一条边是否被所有路径覆盖.同时路径端点集合有加入与删除操作. 想法: 考虑 ...

  9. 【UOJ#207】共价大爷游长沙

    题目链接 题目描述 火车司机出秦川,跳蚤国王下江南,共价大爷游长沙.每个周末,勤劳的共价大爷都会开车游历长沙市. 长沙市的交通线路可以抽象成为一个 \(n\) 个点 \(n−1\) 条边的无向图,点编 ...

随机推荐

  1. enable nested VT in VM

    问题描述: 处理器支持VT-x,并且已经在BIOS中开启了VT-x.在host os上用VMware Workstation安装了一个Ubuntu虚拟机,在虚拟机中执行“cat /proc/cpuin ...

  2. 2015 年最热门的国人开发开源软件 TOP 50

    开源中国在 2015 年得到了快速的发展,单开源软件收藏量就接近 40000 款,其中不乏优质的国产开源项目.本文从软件的收藏.下载.访问等多角度挑选出了 2015 年最热门的国产开源软件前五十名,让 ...

  3. 2018.3.3 How too much fructose may cause liver damage

    Fructose is the sweetest of the natural sugars. As its name suggests, it is found mainly in fruits. ...

  4. ACM学习历程——HDU3333 Turing Tree(线段树 && 离线操作)

    Problem Description After inventing Turing Tree, 3xian always felt boring when solving problems abou ...

  5. 如何解决outlook2013邮件规则for other machine的失效问题

    如何解决outlook2013邮件规则for other machine的失效问题 问题描述:因为重装系统,outlook2013进去后->Rules and Alerts->发现所有原来 ...

  6. [转载]Windows网络编程系列教程之四:Select模型

    原文:http://www.51see.com/asp/bbs/public/bp_show.asp?t_id=200308131152297103 讲一下套接字模式和套接字I/O模型的区别.先说明一 ...

  7. 对于makefile传递参数的一些问题

    makefile变量说明: 1.总控Makefile中使用“-e”参数覆盖下一层Makefile中的变量. 2.父级Makefile向子级Makefile传送变量方式:export <varia ...

  8. Source insight 支持汇编

    把uboot代码添加到SI的项目里面,打开*.S的文件的时候,发现还是黑白色的,感觉很不舒服,我使用的SI的版本是: ver 3.50,通过百度,找到了解决的办法,方法如下: 1:想让*.s 或者 * ...

  9. JS---猜数字(0-100)

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  10. 关于UML图的生成

    想把一个java工程生成UML图非常简单,之前我的eclipse是4.2.0的,没有对应的GEF,所以我索性就直接把工程粘到了My Eclipse中,因为My Eclipse里面有UML自动生成的功能 ...