2018.10.01 bzoj3237: [Ahoi2013]连通图(cdq分治+并查集)
传送门
cdq分治好题。
对于一条边,如果加上它刚好连通的话,那么删掉它会有两个大集合A,B。于是我们先将B中禁用的边连上,把A中禁用的边禁用,再递归处理A;然后把A中禁用的边连上,把B中禁用的边禁用。
这样递归下去用并查集维护答案就行了。
另外,当向上回溯时需要撤销之前的操作,因此需要用栈维护并查集历史信息。
代码:
#include<bits/stdc++.h>
#define N 100005
#define M 200005
using namespace std;
inline int read(){
int ans=0;
char ch=getchar();
while(!isdigit(ch))ch=getchar();
while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
return ans;
}
int tot=0,n,m,k,fa[N],ans[N];
bool ban[M];
struct edge{int u,v;}tt[M],q[M*50];
vector<int>del[N];
inline int find(int x){
if(x!=fa[x])q[++tot]=(edge){x,fa[x]},fa[x]=find(fa[x]);
return fa[x];
}
inline void merge(int u,int v){
int fx=find(u),fy=find(v);
if(fx!=fy)q[++tot]=(edge){fy,fa[fy]},fa[fy]=fx;
}
inline void rec(int l,int r,int tmp){for(int i=l;i<=r;++i)for(int j=0;j<del[i].size();++j)ban[del[i][j]]=tmp;}
inline void add(int l,int r){
for(int i=l;i<=r;++i)for(int j=0;j<del[i].size();++j){
int pos=del[i][j];
if(ban[pos])continue;
merge(tt[pos].u,tt[pos].v);
}
}
inline void clear(int tim){while(tot>tim)fa[q[tot].u]=q[tot].v,--tot;}
inline bool check(int p){
for(int i=0;i<del[p].size();++i){
int fx=find(tt[del[p][i]].u),fy=find(tt[del[p][i]].v);
if(fx!=fy)return 0;
}
return 1;
}
inline void solve(int l,int r){
if(l==r){ans[l]=check(l);return;}
int mid=l+r>>1;
int cnt=tot;
rec(l,mid,1),add(mid+1,r),rec(l,mid,0),solve(l,mid);
clear(cnt);
rec(mid+1,r,1),add(l,mid),rec(mid+1,r,0),solve(mid+1,r);
}
int main(){
n=read(),m=read();
for(int i=1;i<=n;++i)fa[i]=i;
for(int i=1;i<=m;++i)tt[i].u=read(),tt[i].v=read();
k=read();
for(int i=1;i<=k;++i){
int c=read();
for(int j=1;j<=c;++j){
int tmp=read();
del[i].push_back(tmp);
}
}
rec(1,k,1);
for(int i=1;i<=m;++i)if(!ban[i])merge(tt[i].u,tt[i].v);
rec(1,k,0),tot=0,solve(1,k);
for(int i=1;i<=k;++i)puts(ans[i]?"Connected":"Disconnected");
return 0;
}
2018.10.01 bzoj3237: [Ahoi2013]连通图(cdq分治+并查集)的更多相关文章
- 【openjudge】C15C Rabbit's Festival CDQ分治+并查集
题目链接:http://poj.openjudge.cn/practice/C15C/ 题意:n 点 m 边 k 天.每条边在某一天会消失(仅仅那一天消失).问每一天有多少对点可以相互到达. 解法:开 ...
- BZOJ 4025: 二分图 [线段树CDQ分治 并查集]
4025: 二分图 题意:加入边,删除边,查询当前图是否为二分图 本来想练lct,然后发现了线段树分治的做法,感觉好厉害. lct做法的核心就是维护删除时间的最大生成树 首先口胡一个分块做法,和hno ...
- 【CF603E】Pastoral Oddities cdq分治+并查集
[CF603E]Pastoral Oddities 题意:有n个点,依次加入m条边权为$l_i$的无向边,每次加入后询问:当前图是否存在一个生成子图,满足所有点的度数都是奇数.如果有,输出这个生成子图 ...
- hdu_5354_Bipartite Graph(cdq分治+并查集判二分图)
题目链接:hdu_5354_Bipartite Graph 题意: 给你一个由无向边连接的图,问对于每一个点来说,如果删除这个点,剩下的点能不能构成一个二分图. 题解: 如果每次排除一个点然后去DFS ...
- [HDU5354]Bipartite Graph(CDQ分治+并查集)
经典动态二分图问题. 考虑solve(l,r)分治成l,mid和mid+1,r.先将区间[mid+1,r]中的点全部加入图中,若此时存在奇环则ans[l..mid]全部为0,否则递归到左边. 递归完左 ...
- 2018.09.30 bzoj4025: 二分图(线段树分治+并查集)
传送门 线段树分治好题. 这道题实际上有很多不同的做法: cdq分治. lct. - 而我学习了dzyo的线段树分治+并查集写法. 所谓线段树分治就是先把操作分成lognlognlogn个连续不相交的 ...
- 【CF576E】Painting Edges 线段树按时间分治+并查集
[CF576E]Painting Edges 题意:给你一张n个点,m条边的无向图,每条边是k种颜色中的一种,满足所有颜色相同的边内部形成一个二分图.有q个询问,每次询问给出a,b代表将编号为a的边染 ...
- 2015多校第6场 HDU 5354 Bipartite Graph CDQ,并查集
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5354 题意:求删去每个点后图是否存在奇环(n,m<=1e5) 解法:很经典的套路,和这题一样:h ...
- BZOJ_4025_二分图_线段树按时间分治+并查集
BZOJ_4025_二分图_线段树按时间分治+并查集 Description 神犇有一个n个节点的图.因为神犇是神犇,所以在T时间内一些边会出现后消失.神犇要求出每一时间段内这个图是否是二分图.这么简 ...
随机推荐
- cb6xe7代码提示风格变化
- div 标签
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 常用html设置:
省略 居中 1. 省略 ellipsis: text-overflow:ellipsis: 要求容器必须是固定的,要不然无法做省略. table的省略 table{ table_layout:fixe ...
- 基于OpenGL编写一个简易的2D渲染框架-01 创建窗口
最近正在学习OpenGL,我认为学习的最快方法就是做一个小项目了. 如果对OpenGL感兴趣的话,这里推荐一个很好的学习网站 https://learnopengl-cn.github.io/ 我用的 ...
- 12 python json&pickle&shelve模块
1.什么叫序列化 序列化是指把内存里的数据类型转变成字符串,以使其能存储到硬盘或通过网络传输到远程,因为硬盘或网络传输时只能接受bytes(字节) 2.用于序列化的两个模块,json和pickle ...
- 关于eval()函数处理后台返回的json数据
对于服务器返回的JSON字符串,如果jquery异步请求没做类型说明,或者以字符串方式接受,那么需要做一次对象化处理,方式不是太麻烦,就是将该字符串放于eval()中执行一次.这种方式也适合以普通ja ...
- Elon Musk
人物事件 成长学习 年6月28日,埃隆·马斯克在南非的比勒陀利亚出生,他的 埃隆·马斯克 父亲是一名南非机电工程师,母亲是加拿大人,从事营养师兼模特.[8] 年,10岁的马斯克就拥有了自己的第一台电 ...
- git hg提交拉取
工作总结web_acl 535 git clone “ssh://git@outergit.yonyou.com:49622/esn_web/web_acl.git" 600 git bra ...
- Spring Retry
最近组内准备将项目中原有的重试功能抽取出来重构为一个重试平台,由于对重试的功能要求比较高,采用了不少中间件和框架(jimdb,jproxy, Elastic-Job ,JMQ,Hbase, Disru ...
- MySql的基本架构续
[数据拆分后引入的问题] 数据水平拆分引入的问题主要是只能通过sharding key来读写操作,例如以userid为sharding key的切分例子,读userid的详细信息时,一定需要先知道us ...