题目大意:有$n$个点,你需要操作$m$次。每次操作为加入/删除一条边。

问你每次操作后,这$n$个点构成的图是否是二分图。

数据范围:$n,m≤10^5$。

此题并没有强制在线,考虑离线做法。

一条边在某个时间被加入,然后又被删除。

设这条边出现的时间为$[l,r]$,我们开一棵线段树,在对应的区间上标记出这一条线段。

最后我们遍历整个线段树,把这些线段往并查集上加,同时维护当前点的颜色,然后简单判断下就没了。

这个并查集需要支持撤销操作,所以不能路径压缩,需要按秩合并

时间复杂度:$O(n\log^2\ n)$。

 #include<bits/stdc++.h>
#define M 100005
#define mid ((a[x].l+a[x].r)>>1)
using namespace std; int f[M]={},siz[M]={},val[M]={}; int get(int x){return x==f[x]?x:get(f[x]);}
int getdis(int x){return x==f[x]?:val[x]+getdis(f[x]);}
int n,m,ok=;
map<int,int> mp[M]; struct seg{
int l,r; vector<int> u,v,F;
void add(){
int S=u.size();
for(int i=;i<S;i++){
int U=get(u[i]),V=get(v[i]);
if(U==V){
if((getdis(u[i])+getdis(v[i]))%==) ok=;
F.push_back(-); continue;
}
if(siz[U]<siz[V]){swap(U,V); swap(u[i],v[i]);}
int d=getdis(u[i])+getdis(v[i]);
F.push_back(V); f[V]=U; val[V]=(d+)&; siz[U]+=siz[V];
}
}
void del(){
int S=u.size();
for(int i=S-;~i;i--){
if(F[i]==-) continue;
int U=get(u[i]),V=F[i];
siz[U]-=siz[V];
f[V]=V; val[V]=;
}
} }a[M<<]={}; void build(int x,int l,int r){
a[x].l=l; a[x].r=r; if(l==r) return;
build(x<<,l,mid); build(x<<|,mid+,r);
}
void updata(int x,int l,int r,int U,int V){
if(l<=a[x].l&&a[x].r<=r){a[x].u.push_back(U); a[x].v.push_back(V);return;}
if(l<=mid) updata(x<<,l,r,U,V);
if(mid<r) updata(x<<|,l,r,U,V);
} int solve(int x){
int lastok=ok;
a[x].add();
if(ok==) for(int i=a[x].l;i<=a[x].r;i++) printf("NO\n");
else if(a[x].l==a[x].r) printf("YES\n");
else solve(x<<),solve(x<<|);
a[x].del();
ok=lastok;
} int main(){
scanf("%d%d",&n,&m);
build(,,m);
for(int i=;i<=n;i++) f[i]=i,siz[i]=;
for(int i=;i<=m;i++){
int u,v; scanf("%d%d",&u,&v);
if(u<v) swap(u,v);
if(mp[u][v]){
updata(,mp[u][v],i-,u,v);
mp[u][v]=;
}else mp[u][v]=i;
}
for(int i=;i<=n;i++){
for(map<int,int>::iterator it=mp[i].begin();it!=mp[i].end();it++)
if(it->second)
updata(,it->second,m,i,it->first);
}
solve();
}

【xsy2506】 bipartite 并查集+线段树的更多相关文章

  1. UVA1455 - Kingdom(并查集 + 线段树)

    UVA1455 - Kingdom(并查集 + 线段树) 题目链接 题目大意:一个平面内,给你n个整数点,两种类型的操作:road x y 把city x 和city y连接起来,line fnum ...

  2. 并查集&线段树&树状数组&排序二叉树

    超级无敌巨牛逼并查集(带权并查集)https://vjudge.net/problem/UVALive-4487 带删点的加权并查集 https://vjudge.net/problem/UVA-11 ...

  3. 【Codeforces576E_CF576E】Painting Edges(可撤销并查集+线段树分治)

    题目 CF576E 分析: 从前天早上肝到明天早上qwq其实颓了一上午MC ,自己瞎yy然后1A,写篇博客庆祝一下. 首先做这题之前推荐一道很相似的题:[BZOJ4025]二分图(可撤销并查集+线段树 ...

  4. BZOJ 3910 并查集+线段树合并

    思路: 1. 并查集+线段树合并 记得f[LCA]==LCA的时候 f[LCA]=fa[LCA] 2.LCT(并不会写啊...) //By SiriusRen #include <cstdio& ...

  5. 并查集 + 线段树 LA 4730 Kingdom

    题目传送门 题意:训练指南P248 分析:第一个操作可以用并查集实现,保存某集合的最小高度和最大高度以及城市个数.运用线段树成端更新来统计一个区间高度的个数,此时高度需要离散化.这题两种数据结构一起使 ...

  6. YYHS-猜数字(并查集/线段树维护)

    题目描述     LYK在玩猜数字游戏.    总共有n个互不相同的正整数,LYK每次猜一段区间的最小值.形如[li,ri]这段区间的数字的最小值一定等于xi.     我们总能构造出一种方案使得LY ...

  7. luogu5012 水の数列 (并查集+线段树)

    如果我们能求出来每个区间个数的最大分值,那就可以用线段树维护这个东西 然后出答案了 然后这个的求法和(luogu4269)Snow Boots G非常类似,就是我们把数大小排个序,每次都拿<=x ...

  8. 【CF471E】MUH and Lots and Lots of Segments 扫描线+并查集+线段树+set

    [CF471E]MUH and Lots and Lots of Segments 题意:给你平面上n条水平或竖直的,端点在整点处的线段.你需要去掉一些线段的一些部分,使得剩下的图形:1.连通,2.无 ...

  9. bzoj 3237 连通图 - 并查集 - 线段树

    Input Output Sample Input 4 5 1 2 2 3 3 4 4 1 2 4 3 1 5 2 2 3 2 1 2 Sample Output Connected Disconne ...

随机推荐

  1. 2019.01.17 bzoj1854: [Scoi2010]游戏(二分图匹配)

    传送门 二分图匹配菜题. 题意:nnn个二元组(xi,yi)(x_i,y_i)(xi​,yi​),每个二元组可以选一个数总共nnn个数aia_iai​,问将aia_iai​排好序之后从111开始最多可 ...

  2. js保存,获取,删除cookie的操作

    [转]来自:http://blog.csdn.net/itmyhome1990/article/details/7363816 JSP表单页面 <form action="login& ...

  3. R入门(二)-对象以及它们的模式和属性

    对象以及它们的模式和属性 R操作的实体在技术上说是对象.R的对象类型包括数值型,复数型,逻辑型,字符型和原味型. “原子”型对象:对象的元素都是一样的类型或模式,如逻辑向量和字符串向量. 列表对象:列 ...

  4. Educational Codeforces Round 60 C 思维 + 二分

    https://codeforces.com/contest/1117/problem/C 题意 在一个二维坐标轴上给你一个起点一个终点(x,y<=1e9),然后给你一串字符串代表每一秒的风向, ...

  5. boost-使用说明

    1. boost库中大部分组件不需要编译,直接包含对应头文件即可使用,如#include "boost/array.hpp",因为组件的声明和实现都包含在头文件hpp中. 其它一些 ...

  6. base_expr +: width_expr

    在Verilog-1995中,可以选择向量的任一位输出,也可以选择向量的连续几位输出,不过此时连续几位的始 末数值的index需要是常量.而在Verilog-2001中,可以用变量作为index,进行 ...

  7. 利用WCF搭建RESTful--纯代码启动

    最近学习了这几年忽略了的当前几乎所有的开发技术,有深有浅,而服务层最有兴趣的是RESTfull,看的是java的书.因为不熟悉JSP,于是找了本书细细研读了一次. dotnet的实现也相对简单,网上也 ...

  8. day19(乱码解决方案)

    乱码的解决方案: 首先需要理解乱码的产生原因:无非就是编码格式的问题 1.服务器到浏览器 字节流传输时 产生乱码的原因: 1.浏览器打开方式不对(打开时 的方式为默认的方式,各个浏览器的方式都不同) ...

  9. 1.messager消息提示框

    $表示全局对象jquery,此处的alert是用div写的,不是真正的alert.

  10. AngularJS 路由及SPA理解

    一.路由及SPA理解 路由允许我们通过不同的 URL 访问不同的内容,可实现多视图的单页web应用(SPA);通常我们的URL形式为 http://runoob.com/first/page,但在单页 ...