BZOJ 4025 二分图(时间树+并查集)
【题目链接】 http://www.lydsy.com/JudgeOnline/problem.php?id=4025
【题目大意】
给出一张图,有些边只存在一段时间,问在一个每个时间段,
这张图是否是二分图
【题解】
判断是否是二分图只要判断是否存在奇环即可,
我们对时间进行分治,在操作树上加删边,
保留涵盖时间区间的有效操作,将剩余操作按时间划分到两端的子树,
退出子树的时候撤销加边操作。
对于判断奇环,我们用并查集维护每个点与标兵的相对距离的奇偶性即可,
由于需要撤销操作,我们放弃对并查集的压缩操作,
采用按秩合并,保证查询的logn复杂度,同时保存每次合并过程即可。
【代码】
#include <cstdio>
#include <algorithm>
using namespace std;
const int N=300010;
namespace Union_Find_Set{
int st[N],top,f[N],val[N],d[N];
void Initialize(int n){for(int i=1;i<=n;i++)f[i]=i,val[i]=0,d[i]=1;top=0;}
int sf(int x){return f[x]==x?x:sf(f[x]);}
int ask(int x){
int res=0;
for(;x!=f[x];x=f[x])res^=val[x];
return res;
}
void back(int tag){
for(;top!=tag;top--){
if(st[top]<0)d[-st[top]]--;
else{
f[st[top]]=st[top];
val[st[top]]=0;
}
}
}
void Union(int x,int y,int _val){
if(d[x]>d[y])swap(x,y);
if(d[x]==d[y])d[y]++,st[++top]=-y;
f[x]=y; val[x]=_val; st[++top]=x;
}
}
using namespace Union_Find_Set;
struct data{int x,y,l,r;}E[N];
void dfs(int l,int r,int pos){
int t=top;
for(int i=1;i<=pos;i++){
int x=E[i].x,y=E[i].y;
if(E[i].l<=l&&E[i].r>=r){
int fx=sf(x),fy=sf(y);
int val=ask(x)^ask(y)^1;
if(fx==fy){
if(val){
for(int j=l;j<=r;j++)puts("No");
back(t); return;
}
}Union(fx,fy,val);
swap(E[i--],E[pos--]);
}
}if(l==r){puts("Yes");back(t);return;}
int mid=(l+r)>>1,ppos=pos;
for(int i=1;i<=ppos;i++){
if(E[i].l>mid)swap(E[i--],E[ppos--]);
}dfs(l,mid,ppos);
ppos=pos;
for(int i=1;i<=ppos;i++){
if(E[i].r<=mid)swap(E[i--],E[ppos--]);
}dfs(mid+1,r,ppos);
back(t);
}
int n,m,op,x,y,l,r,T;
int main(){
scanf("%d%d%d",&n,&m,&T);
for(int i=1;i<=m;i++){
scanf("%d%d%d%d",&x,&y,&l,&r);
E[i]=(data){x,y,++l,r};
}Initialize(n);
for(int i=1;i<=m;i++)if(E[i].l>E[i].r)swap(E[i],E[m--]);
dfs(1,T,m);
return 0;
}
BZOJ 4025 二分图(时间树+并查集)的更多相关文章
- [BZOJ 4025]二分图(线段树分治+带边权并查集)
[BZOJ 4025]二分图(线段树分治+带边权并查集) 题面 给出一个n个点m条边的图,每条边会在时间s到t出现,问每个时间的图是否为一个二分图 \(n,m,\max(t_i) \leq 10^5\ ...
- BZOJ 4025: 二分图 [线段树CDQ分治 并查集]
4025: 二分图 题意:加入边,删除边,查询当前图是否为二分图 本来想练lct,然后发现了线段树分治的做法,感觉好厉害. lct做法的核心就是维护删除时间的最大生成树 首先口胡一个分块做法,和hno ...
- bzoj 4025 二分图——线段树分治+LCT
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4025 线段树分治,用 LCT 维护链的长度即可.不过很慢. 正常(更快)的方法应该是线段树分 ...
- BZOJ 4551 [Tjoi2016&Heoi2016]树 ——并查集
树剖显然可以做. 然而有一种更神奇的方法,并查集+时光倒流. 每个节点指向它上面最近的标记节点,标记节点指向自己,然后删除标记,就可以用并查集查询了. #include <map> #in ...
- BZOJ 1453 (线段树+并查集)
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1453 题意:一个 n*n 的矩阵,每个位置有黑/白两种颜色,有 m 次操作,每次可以翻转 ...
- BZOJ 4551: [Tjoi2016&Heoi2016]树 并查集(&&图论?)
反向操作,先把所有的标记都打上(记得统计标记的数目),然后依次撤销,合并到自己的上一个点pre,即fa[u]=getf(pre[u]) #include<cstdio> #include& ...
- bzoj 4025 二分图 分治+并查集/LCT
bzoj 4025 二分图 [题目大意] 有n个点m条边,边会在start时刻出现在end时刻消失,求对于每一段时间,该图是不是一个二分图. 判断二分图的一个简单的方法:是否存在奇环 若存在奇环,就不 ...
- BZOJ_4025_二分图_线段树按时间分治+并查集
BZOJ_4025_二分图_线段树按时间分治+并查集 Description 神犇有一个n个节点的图.因为神犇是神犇,所以在T时间内一些边会出现后消失.神犇要求出每一时间段内这个图是否是二分图.这么简 ...
- 【CF576E】Painting Edges 线段树按时间分治+并查集
[CF576E]Painting Edges 题意:给你一张n个点,m条边的无向图,每条边是k种颜色中的一种,满足所有颜色相同的边内部形成一个二分图.有q个询问,每次询问给出a,b代表将编号为a的边染 ...
随机推荐
- HDU 1548 A strange lift (广搜)
题目链接 Problem Description There is a strange lift.The lift can stop can at every floor as you want, a ...
- MongoDB 数据库(2)
db.collectionName 集合对象 获取集合对象 db.getCollection('collection_name') e.g. db.getCollection("class0 ...
- Java中的return语句使用总结
Java中的return语句总是和方法有密切关系,return语句总是用在方法中,有两个作用,一个是返回方法指定类型的值(这个值总是确定的),一个是结束方法的执行(仅仅一个return语句). 在 ...
- static class 和 non static class 的区别
static class non static class 1.用static修饰的是内部类,此时这个 内部类变为静态内部类:对测试有用: 2.内部静态类不需要有指向外部类的引用: 3.静态类只能访问 ...
- Python3 Socket和SocketServer 网络编程
socket只能实现同时一个服务和一个客户端实现交互,socketserver可以实现多个客户端同时和服务端交互 1.利用Socket编写简单的同一个端口容许多次会话的小案例: 服务端: #!/usr ...
- 浅谈C语言中的强符号、弱符号、强引用和弱引用【转】
转自:http://www.jb51.net/article/56924.htm 首先我表示很悲剧,在看<程序员的自我修养--链接.装载与库>之前我竟不知道C有强符号.弱符号.强引用和弱引 ...
- python基础===获取知乎标题时候,文件编码失败的总结
总结一下,关于获取到的信息编码失败. 刚才在执行代码的时候,发现一个问题: 然后修改代码如下: '''爬取知乎界面的标题''' import requests import re import sys ...
- Django===django工作流
通过一张图来总结一下Django 的处理过程: URL 组成: 协议类型: HTTP/HTTPS HTTP 协议(HyperText Transfer Protocol,超文本传输协议)是用于从WWW ...
- 单从软件层面来说,Maya 和 Blender 差别在哪?
单从软件层面来说,Maya 和 Blender 差别在哪? https://www.zhihu.com/question/21975571
- Centos. Mac 通过nfs 搭建共享目录
centos 关闭fiewalld,selinux yum install yum install nfs-utils portmap vim /etc/exports 文件写入时使用anonuid用 ...