【题目链接】 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 二分图(时间树+并查集)的更多相关文章

  1. [BZOJ 4025]二分图(线段树分治+带边权并查集)

    [BZOJ 4025]二分图(线段树分治+带边权并查集) 题面 给出一个n个点m条边的图,每条边会在时间s到t出现,问每个时间的图是否为一个二分图 \(n,m,\max(t_i) \leq 10^5\ ...

  2. BZOJ 4025: 二分图 [线段树CDQ分治 并查集]

    4025: 二分图 题意:加入边,删除边,查询当前图是否为二分图 本来想练lct,然后发现了线段树分治的做法,感觉好厉害. lct做法的核心就是维护删除时间的最大生成树 首先口胡一个分块做法,和hno ...

  3. bzoj 4025 二分图——线段树分治+LCT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4025 线段树分治,用 LCT 维护链的长度即可.不过很慢. 正常(更快)的方法应该是线段树分 ...

  4. BZOJ 4551 [Tjoi2016&Heoi2016]树 ——并查集

    树剖显然可以做. 然而有一种更神奇的方法,并查集+时光倒流. 每个节点指向它上面最近的标记节点,标记节点指向自己,然后删除标记,就可以用并查集查询了. #include <map> #in ...

  5. BZOJ 1453 (线段树+并查集)

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1453 题意:一个 n*n 的矩阵,每个位置有黑/白两种颜色,有 m 次操作,每次可以翻转 ...

  6. BZOJ 4551: [Tjoi2016&Heoi2016]树 并查集(&&图论?)

    反向操作,先把所有的标记都打上(记得统计标记的数目),然后依次撤销,合并到自己的上一个点pre,即fa[u]=getf(pre[u]) #include<cstdio> #include& ...

  7. bzoj 4025 二分图 分治+并查集/LCT

    bzoj 4025 二分图 [题目大意] 有n个点m条边,边会在start时刻出现在end时刻消失,求对于每一段时间,该图是不是一个二分图. 判断二分图的一个简单的方法:是否存在奇环 若存在奇环,就不 ...

  8. BZOJ_4025_二分图_线段树按时间分治+并查集

    BZOJ_4025_二分图_线段树按时间分治+并查集 Description 神犇有一个n个节点的图.因为神犇是神犇,所以在T时间内一些边会出现后消失.神犇要求出每一时间段内这个图是否是二分图.这么简 ...

  9. 【CF576E】Painting Edges 线段树按时间分治+并查集

    [CF576E]Painting Edges 题意:给你一张n个点,m条边的无向图,每条边是k种颜色中的一种,满足所有颜色相同的边内部形成一个二分图.有q个询问,每次询问给出a,b代表将编号为a的边染 ...

随机推荐

  1. VSCode Web Developement for Javascript. Must have plugins.

    Es6 Javascript front-end web developemnt must have plugins Prettier - Code Formatter Javascript (ES6 ...

  2. POJ 3279 Fliptile ( 开关问题)

    题目链接 Description Farmer John knows that an intellectually satisfied cow is a happy cow who will give ...

  3. EF添加ADO.NET实体模型处直接选择Oracle数据源

    上一文介绍了如何下载Mysql for vs Tools来进行Mysql的ADO.NET实体模型数据源选择,今天将Oracle的测试了下.步骤如下: 1.在你项目Model层中nuget安装选中项 2 ...

  4. 神奇JavaScript框架---Top5

    前言 个人观点,供您参考 观点源自作者的使用经验和日常研究 排名基于框架的受欢迎度, 语法结构, 易用性等特性 希望大家能够基于此视频找到最适合自己的框架 下面介绍的都是严格的前端框架和库 前言 To ...

  5. NOIP 2010

    tags: NOIP 并查集 动态规划 搜索 categories: 信息学竞赛 总结 机器翻译 乌龟棋 关押罪犯 引水入城 机器翻译 Solution 维护一个队列, 每次从词典中查词时将单词加入队 ...

  6. django “如何”系列1:如何使用REMOTE_USER(远程用户)进行认证

    这节主要介绍当web服务器使用了REMOTE_USER的时候,该如何在你的django应用中使用外部的认证源,远程用户主要见于企业内部网,主要使用单点登录解决方案. 在django中,REMOTE_U ...

  7. 【python】msgpack使用

    1.存储数据 import msgpack var={'a':'this','b':'is','c':'a test'} with open('file.name','wb') as f: msgpa ...

  8. 我是如何向老婆解释MapReduce的?

    转载自:<我是如何向老婆解释MapReduce的?> 昨天,我在Xebia印度办公室发表了一个关于MapReduce的演说.演说进行得很顺利,听众们都能够理解MapReduce的概念(根据 ...

  9. CentOS 7下OpenLDAP编译安装及配置

    一.环境 Server:基于CentOS-7-x86_64-1511 Server IP: 172.18.12.203 二.软件获取 OpenLDAP OpenLDAP官网下载地址:http://ww ...

  10. 一款简洁而强大的前端框架—JQuery

    jQuery是什么? jQuery是一个快速.简洁的JavaScript框架,它封装JavaScript常用的功能代码,提供一种简便的JavaScript设计模式,优化HTML文档操作.事件处理.动画 ...