传送门

解题思路

  可以离线,然后确定每个边的出现时间,算这个排序即可。然后就可以线段树分治了,连通性用并查集维护,因为要撤销,所以要按秩合并,时间复杂度\(O(nlog^2 n)\)

代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector> using namespace std;
const int N=100005; inline int rd(){
int x=0; char ch=getchar();
while(!isdigit(ch)) ch=getchar();
while(isdigit(ch)) x=(x<<1)+(x<<3)+ch-'0',ch=getchar();
return x;
} int n,tot,ans[N],fa[N<<1],siz[N<<1],num,cnt;
struct Data{
int x,y,op,id;
friend bool operator<(const Data A,const Data B){
if(A.x==B.x && A.y==B.y) return A.id<B.id;
if(A.x==B.x) return A.y<B.y;
return A.x<B.x;
}
}tmp[N],ask[N];
struct Node{
int x,y,t;
Node(int _x=0,int _y=0,int _t=0){
x=_x; y=_y; t=_t;
}
}; inline int id(int x,int y){
return (x-1)*n+y;
}
inline int get(int x){
while(x!=fa[x]) x=fa[x];
return x;
} struct Segment_Tree{
vector<Node> v[N<<2];
vector<Node> Ask[N];
void update(int x,int l,int r,int L,int R,Node now){
if(L<=l && r<=R){
if(now.t) Ask[l].push_back(now);
else v[x].push_back(now);
return ;
}
int mid=(l+r)>>1;
if(L<=mid) update(x<<1,l,mid,L,R,now);
if(mid<R) update(x<<1|1,mid+1,r,L,R,now);
}
void query(int x,int l,int r){
int xx,yy,uu,vv; vector<Node> now;
for(int i=0;i<v[x].size();i++){
xx=v[x][i].x; yy=v[x][i].y;
uu=get(xx); vv=get(yy);
if(uu==vv) continue;
if(siz[uu]<siz[vv]) swap(uu,vv);
siz[uu]+=siz[vv]; fa[vv]=uu;
now.push_back(Node(uu,vv,0));
}
int mid=(l+r)>>1;
if(l==r){
for(int i=0;i<Ask[l].size();i++) {
xx=get(Ask[l][i].x); yy=get(Ask[l][i].y);
ans[Ask[l][i].t]=(xx==yy)?1:0;
}
}
else query(x<<1,l,mid),query(x<<1|1,mid+1,r);
for(int i=0;i<now.size();i++){
xx=now[i].x; yy=now[i].y;
fa[yy]=yy; siz[xx]-=siz[yy];
}
}
}tree; int main(){
n=rd(); int x1,y1,x2,y2,id1,id2; char s[10];
for(int i=1;i<=n*2;i++) fa[i]=i,siz[i]=1;
while(1){
scanf("%s",s+1);
if(s[1]=='E') break; cnt++;
x1=rd(),y1=rd(),x2=rd(),y2=rd();
id1=id(x1,y1); id2=id(x2,y2);
if(id1>id2) swap(id1,id2);
if(s[1]=='A') {
num++; ask[num].id=cnt;
ask[num].x=id1; ask[num].y=id2;
continue;
}
tot++; tmp[tot].id=cnt;
tmp[tot].x=id1; tmp[tot].y=id2;
if(s[1]=='O') tmp[tot].op=0;
else tmp[tot].op=1;
}
sort(tmp+1,tmp+1+tot);
for(int i=1;i<=num;i++)
tree.update(1,1,cnt,ask[i].id,ask[i].id,Node(ask[i].x,ask[i].y,i));
for(int i=1;i<=tot;i++){
if(tmp[i].op==0 && tmp[i+1].x==tmp[i].x && tmp[i+1].y==tmp[i].y)
tree.update(1,1,cnt,tmp[i].id,tmp[i+1].id,Node(tmp[i].x,tmp[i].y,0)),++i;
else tree.update(1,1,cnt,tmp[i].id,cnt,Node(tmp[i].x,tmp[i].y,0));
}
tree.query(1,1,cnt);
for(int i=1;i<=num;i++)
puts(ans[i]?"Y":"N");
return 0;
}

BZOJ 1018: [SHOI2008]堵塞的交通traffic(线段树分治+并查集)的更多相关文章

  1. BZOJ 1018: [SHOI2008]堵塞的交通traffic [线段树 区间信息]

    1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 3064  Solved: 1027[Submi ...

  2. Bzoj1018/洛谷P4246 [SHOI2008]堵塞的交通(线段树分治+并查集)

    题面 Bzoj 洛谷 题解 考虑用并查集维护图的连通性,接着用线段树分治对每个修改进行分治. 具体来说,就是用一个时间轴表示图的状态,用线段树维护,对于一条边,我们判断如果他的存在时间正好在这个区间内 ...

  3. 数据结构(线段树):BZOJ 1018: [SHOI2008]堵塞的交通traffic

    1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 2638  Solved: 864 Descri ...

  4. BZOJ 1018 [SHOI2008]堵塞的交通traffic

    1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 2247  Solved: 706[Submit ...

  5. [BZOJ1018][SHOI2008]堵塞的交通traffic 线段树维护连通性

    1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec  Memory Limit: 162 MB Submit: 3795  Solved: 1253 [Sub ...

  6. 【BZOJ1018】[SHOI2008]堵塞的交通traffic 线段树

    [BZOJ1018][SHOI2008]堵塞的交通traffic Description 有一天,由于某种穿越现象作用,你来到了传说中的小人国.小人国的布局非常奇特,整个国家的交通系统可以被看成是一个 ...

  7. [BZOJ 1018] [SHOI2008] 堵塞的交通traffic 【线段树维护联通性】

    题目链接:BZOJ - 1018 题目分析 这道题就说明了刷题少,比赛就容易跪..SDOI Round1 Day2 T3 就是与这道题类似的..然而我并没有做过这道题.. 这道题是线段树维护联通性的经 ...

  8. BZOJ 1018: [SHOI2008]堵塞的交通traffic(线段树)

    题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1018 用线段树维护区间连通性,对于每一个区间记录6个域表示(左上,左下)(左上,右上)(右上, ...

  9. 【bzoj1018】[SHOI2008]堵塞的交通traffic 线段树区间合并+STL-set

    题目描述 给出一张2*n的网格图,初始每条边都是不连通的.多次改变一条边的连通性或询问两个点是否连通. 输入 第一行只有一个整数C,表示网格的列数.接下来若干行,每行为一条交通信息,以单独的一行“Ex ...

随机推荐

  1. javascript 调试 使用console.table()

    或许你已经习惯了console.log()来调试js,非常使用,但是今天微博看到console.table()调试javascript,和console.log()类似,主要区别在于: 主要用来输出对 ...

  2. Proxifier全局代理

    0x00前言   成功搭建使用shadowshocks实现代理访问google,然而只能浏览器代理方式使用,不能其他程序使用代理,不利于白帽子匿名安全检测,下面将介绍利用Proxifier实现全局代理 ...

  3. Python的一些高级特性

    内容基本上来自于廖雪峰老师的blog相当于自己手打了一遍,加强加强理解吧. http://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493 ...

  4. [BZOJ2438]杀人游戏

    Description 一位冷血的杀手潜入 Na-wiat,并假装成平民.警察希望能在 N 个人里面,查出谁是杀手.警察能够对每一个人 进行查证,假如查证的对象是平民,他会告诉警察,他认识的人, 谁是 ...

  5. go 结构体取代类

    我们知道go的结构体有点类的感觉,可以有自己的属性和方法. 但是由于结构体的属性都是有零值的,我们在创建结构体的时候并不需要设置这些属性的值就能创建,但是这样创建的结构体往往没有什么实用价值. 我们可 ...

  6. 详解Twitter开源分布式自增ID算法snowflake(附演算验证过程)

    详解Twitter开源分布式自增ID算法snowflake,附演算验证过程 2017年01月22日 14:44:40 url: http://blog.csdn.net/li396864285/art ...

  7. SQL server 聚集索引与主键的区别

    主键是一个约束(constraint),他依附在一个索引上,这个索引可以是聚集索引,也可以是非聚集索引. 所以在一个(或一组)字段上有主键,只能说明他上面有个索引,但不一定就是聚集索引. 例如下面: ...

  8. ApacheHttpServer修改httpd.conf配置文件

    转自:https://blog.csdn.net/dream1120757048/article/details/77427351 1. 安装完 Apache HTTP Server 之后,还需要修改 ...

  9. tensorflow用dropout解决over fitting

    在机器学习中可能会存在过拟合的问题,表现为在训练集上表现很好,但在测试集中表现不如训练集中的那么好. 图中黑色曲线是正常模型,绿色曲线就是overfitting模型.尽管绿色曲线很精确的区分了所有的训 ...

  10. 天启android5.1系统无法在非1650批次号的rk3288w芯片上启动

    天启android5.1系统无法在非1650批次号的rk3288w芯片上启动 挂掉log,说明在rtc初始化后挂掉 [ ) HIGH! ======== [ [ [ 1.420258] [WLAN_R ...