【题目链接】 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. Java 对象排序详解

    很难想象有Java开发人员不曾使用过Collection框架.在Collection框架中,主要使用的类是来自List接口中的ArrayList,以及来自Set接口的HashSet.TreeSet,我 ...

  2. 双关键字LIS

    首先对于双关键字的LIS有一个比较暴力的方法,就是线段树套平衡树,我们把双关键字的LIS抽象成二维坐标系中的点,这样我们对于当前转移的点i(x,y),需要找的就是在(xx,yy)xx<x,yy& ...

  3. 各浏览器的Hack写法【转】

    Hack是针对不同的浏览器去写不同的CSS样式,从而让各浏览器能达到一致的渲染效果,那么针对不同的浏览器写不同的CSS CODE的过程,就叫CSS HACK,同时也叫写CSS Hack.然后将Hack ...

  4. kndo grid:通过checkbox 实现多选和全选

    在kendo grid 里要想通过checkbox 实现多选和权限,我们就要通过templeate 和input 标签对kendo grid 进行自定义 1. 在column 里面加入一列checkb ...

  5. adb操作指令大全

    adb是什么?:adb的全称为Android Debug Bridge,就是起到调试桥的作用.通过adb我们可以在Eclipse中方面通过DDMS来调试android程序,说白了就是debug工具.a ...

  6. mysql中的单引号/小数点/字符转换为数字/警告信息

    我们准备玩点有趣的: select 一个数字: mysql from mysql.user; +---+ | +---+ | | | +---+ rows in set (0.00 sec) mysq ...

  7. mysql执行load_fle返回NULL的解决方法

    mysql 版本: 5.7.18 问题: 在执行mysql 函数load_file时,该函数将加载指定文件的内容,存储至相应字段.如: SELECT LOAD_FILE("D:\aa.txt ...

  8. LINUX-内核-中断分析-中断向量表(3)-arm【转】

    转自:http://blog.csdn.net/haolianglh/article/details/51986987 arm中断概念 在<ARM体系结构与编程>第9章中说到,ARM 中有 ...

  9. linux sftp and unix ftp

    sftp 1.功能作用 sftp 是一个交互式文件传输程式.它类似于 ftp, 但它进行加密传输,比FTP有更高的安全性. 2.位置 /usr/bin/sftp 3.格式用法 sftp [-1246C ...

  10. ansible安装和配置

    一.安装ansible准备 //安装准备 .两台机器 172.7.15.106 172.7.15.111 .设置hostname以及hosts 172.7.15.106 web9.lulu.com 1 ...