思路

同LOJ121

动态图连通性的板子

好像有很神的线段树做法,不会,先码住

代码

#include <cstdio>
#include <algorithm>
#include <cstring>
#include <stack>
#include <map>
#include <set>
#include <vector>
using namespace std;
const int MAXN = 100100;
int c,n,time,ans[MAXN],anscnt;
char s[MAXN];
inline int id(int rr,int cc){
return (rr-1)*c+cc;
}
struct uDSU{
int h[MAXN],fa[MAXN];
stack<int> height,mer;
int find(int x){
if(x==fa[x])
return x;
else
return find(fa[x]);
}
void merge(int x,int y){
x=find(x);
y=find(y);
if(h[x]<=h[y]){
fa[x]=y;
mer.push(x);
if(h[x]==h[y]){
h[y]++;
height.push(1);
}
else{
height.push(0);
}
}
else{
fa[y]=x;
mer.push(y);
height.push(0);
}
}
bool query(int x,int y){
return find(x)==find(y);
}
void undo(void){
int val=height.top();
height.pop();
int x=mer.top();
mer.pop();
h[fa[x]]-=val;
fa[x]=x;
}
void init(void){
for(int i=1;i<=n;i++)
h[i]=1,fa[i]=i;
}
}DSU;
map<pair<int,int>,int > M;
struct Node{
int le,u,v;
bool operator < (const Node &b) const{
return le<b.le;
}
};
vector<Node> seg[MAXN<<2];
void add(int L,int R,int l,int r,int o,int le,int u,int v){
if(L<=l&&r<=R){
seg[o].push_back((Node){le,u,v});
return;
}
int mid=(l+r)>>1;
if(L<=mid)
add(L,R,l,mid,o<<1,le,u,v);
if(R>mid)
add(L,R,mid+1,r,o<<1|1,le,u,v);
}
void dfs(int o,int l,int r){
sort(seg[o].begin(),seg[o].end());
for(int i=0;i<seg[o].size();i++)
if(seg[o][i].le==-1)
DSU.merge(seg[o][i].u,seg[o][i].v);
else
ans[seg[o][i].le]=DSU.query(seg[o][i].u,seg[o][i].v);
if(l!=r){
int mid=(l+r)>>1;
dfs(o<<1,l,mid);
dfs(o<<1|1,mid+1,r);
}
for(int i=0;i<seg[o].size();i++)
if(seg[o][i].le==-1)
DSU.undo();
}
int main(){
scanf("%d",&c);
n=c*2;
DSU.init();
scanf("%s",s);
while(s[0]!='E'){
++time;
int r1,c1,r2,c2;
scanf("%d %d %d %d",&r1,&c1,&r2,&c2);
int x=id(r1,c1),y=id(r2,c2);
if(x>y)
swap(x,y);
if(s[0]=='C'){
add(M[make_pair(x,y)],time,1,100010,1,-1,x,y);
M.erase(make_pair(x,y));
}
if(s[0]=='O'){
M[make_pair(x,y)]=time;
}
if(s[0]=='A'){
add(time,time,1,100010,1,++anscnt,x,y);
}
scanf("%s",s);
}
++time;
for(map<pair<int,int>,int >::iterator it=M.begin();it!=M.end();it++)
add((*it).second,time,1,100010,1,-1,(*it).first.first,(*it).first.second);
dfs(1,1,100010);
for(int i=1;i<=anscnt;i++)
printf("%s\n",(ans[i])?"Y":"N");
return 0;
}

P4246 [SHOI2008]堵塞的交通的更多相关文章

  1. Luogu P4246 [SHOI2008]堵塞的交通(线段树+模拟)

    P4246 [SHOI2008]堵塞的交通 题意 题目描述 有一天,由于某种穿越现象作用,你来到了传说中的小人国.小人国的布局非常奇特,整个国家的交通系统可以被看成是一个\(2\)行\(C\)列的矩形 ...

  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. BZOJ 1018: [SHOI2008]堵塞的交通traffic [线段树 区间信息]

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

  6. bzoj千题计划108:bzoj1018: [SHOI2008]堵塞的交通traffic

    http://www.lydsy.com/JudgeOnline/problem.php?id=1018 关键点在于只有两行 所以一个2*m矩形连通情况只有6种 编号即对应代码中的a数组 线段树维护 ...

  7. 【BZOJ1018】[SHOI2008]堵塞的交通

    [BZOJ1018][SHOI2008]堵塞的交通 题面 bzoj 洛谷 洛谷 题解 菊队讲要用线段树维护连通性,但是好像没人写 解法一 将所有的加边删边离线,然后以最近删除时间为边权,$LCT$维护 ...

  8. 1018: [SHOI2008]堵塞的交通traffic

    1018: [SHOI2008]堵塞的交通traffic 链接 分析: 用线段树维护区间的四个端点的联通情况,然后查询的时候,把所有覆盖到的区间合并起来即可. 六种情况左上到右上(左边到右边的情况)… ...

  9. 【bzoj1018】[SHOI2008]堵塞的交通traffic

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

随机推荐

  1. css 渐变动画

    就是这样 这是一段可选文字 -------------------------------------- 代码如下 CSS代码: @media all and (-webkit-min-device- ...

  2. 编写python的程序

    执行python程序有两种方式:      1.交互式环境:输入代码立即执行              优点:调试程序方便              缺点:无法永久保存程序      2.代码写入文件 ...

  3. Robot Framework 教程 (3) - Resource及关键字 的使用

    From:http://www.cnblogs.com/buaawp/p/4754399.html Robot Framework 教程 (3) - Resource及关键字 的使用 在进行软件自动化 ...

  4. PGPDesktop在win7环境下的安装和使用

    PGPDesktop在win7环境下的安装和使用 PGP的简介 PGP(Pretty Good Privacy),是一个基于RSA公钥加密体系的邮件加密软件,它提供了非对称加密和数字签名,是目前非常流 ...

  5. GCD(Swift)

    1.取消过去的接口 说起 GCD, 大家肯定回想起类似 dispatch_async 这样的语法. GCD 的这个语法模式无论是和 Objc 还是 Swift 的整体风格都不太打掉. 所以 Swift ...

  6. Java并发编程1--synchronized关键字用法详解

    1.synchronized的作用 首先synchronized可以修饰方法或代码块,可以保证同一时刻只有一个线程可以执行这个方法或代码块,从而达到同步的效果,同时可以保证共享变量的内存可见性 2.s ...

  7. I2S接口介绍

    I2S接口介绍一.I2S协议介绍 I2S协议作为音频数据传输协议,由Philips制定.该协议由三条数据线组成:1.SCLK:串行时钟,频率= 2 * 采样频率 * 采样位数.2.WS:字段(声道)选 ...

  8. HDU 1527 取石子游戏 (威佐夫博弈)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1527 有两堆石子,数量任意,可以不同.游戏开始由两个人轮流取石子.游戏规定,每次有两种不同的取法,一是 ...

  9. Django之富文本编辑器

    1.在虚拟环境中安装包. pip install django-tinymce==2.6.0 2.在配置文件中INSTALLED_APPS注册 3.配置富文本编辑器的宽高 4.配置编辑器url.

  10. C++重载>>和<<(输入输出运算符)

    在C++中,标准库本身已经对左移运算符<<和右移运算符>>分别进行了重载,使其能够用于不同数据的输入输出,但是输入输出的对象只能是 C++ 内置的数据类型(例如 bool.in ...