uoj207共价大爷游长沙
话说我可能还没有调出魔法森林呢。。。说好的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共价大爷游长沙的更多相关文章
- [UOJ207]共价大爷游长沙
UOJ sol 这题真是太神啦! 对于S集合中的每个点对,给他们随机附上一个相同权值. 两个点在边(x,y)的两侧当且仅当一个点在x的子树中,另一个点不在x的子树中(假设x是y的儿子) 维护一下子树点 ...
- uoj207 共价大爷游长沙 子树信息 LCT + 随机化 + 路径覆盖
题目传送门 http://uoj.ac/problem/207 题解 如果是一棵静态的树,有一个非常容易想到的算法:统计一下目前的每一个条边被几条路径经过,如果 \(x\) 到 \(y\) 的边的这个 ...
- 【LCT维护子树信息】uoj207 共价大爷游长沙
这道题思路方面就不多讲了,主要是通过这题学一下lct维护子树信息. lct某节点u的子树信息由其重链的一棵splay上信息和若干轻儿子子树信息合并而成. splay是有子树结构的,可以在rotate, ...
- 【UOJ207】共价大爷游长沙(Link-Cut Tree,随机化)
[UOJ207]共价大爷游长沙(Link-Cut Tree,随机化) 题面 UOJ 题解 这题太神了 \(\%\%\%myy\) 看到动态的维护边很容易的想到了\(LCT\) 然后能否堵住一条路 我们 ...
- 「UOJ207」共价大爷游长沙
「UOJ207」共价大爷游长沙 解题思路 : 快速判断两个集合是否完全相等可以随机点权 \(\text{xor}\) 的思路可以用到这道题上面,给每一条路径随机一个点权,维护出经过每一条边的点权的 \ ...
- UOJ #207. 共价大爷游长沙 [lct 异或]
#207. 共价大爷游长沙 题意:一棵树,支持加边删边,加入点对,删除点对,询问所有点对是否经过一条边 一开始一直想在边权上做文章,或者从连通分量角度考虑,比较接近正解了,但是没想到给点对分配权值所以 ...
- 【刷题】UOJ #207 共价大爷游长沙
火车司机出秦川,跳蚤国王下江南,共价大爷游长沙.每个周末,勤劳的共价大爷都会开车游历长沙市. 长沙市的交通线路可以抽象成为一个 \(n\) 个点 \(n−1\) 条边的无向图,点编号为 \(1\) 到 ...
- UOJ #207. 共价大爷游长沙
#207. 共价大爷游长沙 链接:http://uoj.ac/problem/207 题意:给一棵树,要求支持加边.删边.询问一条边是否被所有路径覆盖.同时路径端点集合有加入与删除操作. 想法: 考虑 ...
- 【UOJ#207】共价大爷游长沙
题目链接 题目描述 火车司机出秦川,跳蚤国王下江南,共价大爷游长沙.每个周末,勤劳的共价大爷都会开车游历长沙市. 长沙市的交通线路可以抽象成为一个 \(n\) 个点 \(n−1\) 条边的无向图,点编 ...
随机推荐
- 英语影视台词---无敌破坏王2大脑互联网(3)((Ralph)我们去喝根汁汽水吧)
英语影视台词---无敌破坏王2大脑互联网(3)((Ralph)我们去喝根汁汽水吧) 一.总结 一句话总结: Let's go get a root beer. 1.(Ralph)让我来瞧瞧你的本事 ...
- div img 垂直水平居中
<style> div { width: 600px; height: 578px; text-align: center; display: table-cell; vertical-a ...
- 如何通过giihub下载软件
因为不懂英文, 所以找到了网站也不知道要怎么下载? 需求: 假设要下载的的一个jar包, mybatis-generator 1. 利用搜索引擎 2. 点进去, 看到那个release (rel ...
- ActivityMq的使用(小例子)
一.ActivityMq的介绍: 1.什么是消息中间件?与传统的传输通讯有什么区别? 异步,无需等待,消息存放在队列里面. 2.为什么要使用消息中间件? 消息中间件可以解决高并发. 两种通讯方式:01 ...
- Confd 配置指导
Quick Start Guide Before we begin be sure to download and install confd. Select a backend confd supp ...
- BZOJ1878:[SDOI2009]HH的项链
浅谈树状数组与线段树:https://www.cnblogs.com/AKMer/p/9946944.html 题目传送门:https://www.lydsy.com/JudgeOnline/prob ...
- 洛谷 P4721 [模板]分治FFT —— 分治FFT / 多项式求逆
题目:https://www.luogu.org/problemnew/show/P4721 分治做法,考虑左边对右边的贡献即可: 注意最大用到的 a 的项也不过是 a[r-l] ,所以 NTT 可以 ...
- noip2011普及组:统计单词
题目描述 一般的文本编辑器都有查找单词的功能,该功能可以快速定位特定单词在文章中的位 置,有的还能统计出特定单词在文章中出现的次数. 现在,请你编程实现这一功能,具体要求是:给定一个单词,请你输出它在 ...
- MyEclipse修改Servlet模板
进入myeclipse的安装路径 然后进入plugins文件夹 打开搜索框,输入 *wizard* 找到名字是 com.genuitec.eclipse.wizards_11.5.0.me201310 ...
- zk 10之:Curator之三:服务的注册及发现
Service Discovery 我们通常在调用服务的时候,需要知道服务的地址,端口,或者其他一些信息,通常情况下,我们是把他们写到程序里面,但是随着服务越来越多,维护起来也越来越费劲,更重要的是, ...