描述


http://www.lydsy.com/JudgeOnline/problem.php?id=1018

\(2*n\)的距形,起初没有边相连,之后有三种操作:

1.加边.

2.删边.

3.询问某两个点是否联通.

分析


这题太神了...

用线段树维护连通性...

放弃解释清楚了...

 #include <bits/stdc++.h>
using namespace std; const int maxn=1e5+;
int n,cnt;
char s[];
bool A[maxn][];
struct node{
bool a[][];
node(){
a[][]=a[][]=a[][]=a[][]=false;
}
bool* operator [] (int id){return a[id];}
}a[maxn<<];
struct Segment_tree{
node merge(bool *a,node x,node y){
node t;
t[][]=(x[][]&a[]&y[][])|(x[][]&a[]&y[][]);
t[][]=(x[][]&a[]&y[][])|(x[][]&a[]&y[][]);
t[][]=(x[][]&a[]&y[][])|(x[][]&a[]&y[][]);
t[][]=(x[][]&a[]&y[][])|(x[][]&a[]&y[][]);
return t;
}
void build_tree(int l,int r,int k){
if(l==r){a[k][][]=a[k][][]=true;return;}
int mid=l+(r-l)/;
build_tree(l,mid,k<<); build_tree(mid+,r,k<<|);
}
void update(int l,int r,int k,int pos,bool op,bool dir){
if(l==r){
if(dir) a[k][][]=a[k][][]=op;//c
return;
}
int mid=l+(r-l)/;
if(!dir&&pos==mid){//r
a[k]=merge(A[mid],a[k<<],a[k<<|]);
return;
}
if(pos<=mid) update(l,mid,k<<,pos,op,dir);
else update(mid+,r,k<<|,pos,op,dir);
a[k]=merge(A[mid],a[k<<],a[k<<|]);
}
void _get_right(int l,int r,int k,int &pos,node &t,bool dir){
if(l==r) return;
int mid=l+(r-l)/;
node tmp=merge(A[l-],t,a[k<<]);
if(tmp[dir][]||tmp[dir][]) pos=mid, t=tmp, _get_right(mid+,r,k<<|,pos,t,dir);
else _get_right(l,mid,k<<,pos,t,dir);
}
void _get_left(int l,int r,int k,int &pos,node &t,bool dir){
if(l==r) return;
int mid=l+(r-l)/;
node tmp=merge(A[r],a[k<<|],t);
if(tmp[][dir]||tmp[][dir]) pos=mid+,t=tmp, _get_left(l,mid,k<<,pos,t,dir);
else _get_left(mid+,r,k<<|,pos,t,dir);
}
void get_right(int l,int r,int k,int &pos,node &t,bool dir){
if(l==r) {t=a[k];return;}
int mid=l+(r-l)/;
if(pos>mid) get_right(mid+,r,k<<|,pos,t,dir);
else{
get_right(l,mid,k<<,pos,t,dir);
if(pos!=mid) return;
node tmp=merge(A[mid],t,a[k<<|]);
if(tmp[dir][]||tmp[dir][]) pos=r,t=tmp;
else _get_right(mid+,r,k<<|,pos,t,dir);
}
}
void get_left(int l,int r,int k,int &pos,node &t,bool dir){
if(l==r) {t=a[k];return;}
int mid=l+(r-l)/;
if(pos<=mid) get_left(l,mid,k<<,pos,t,dir);
else{
get_left(mid+,r,k<<|,pos,t,dir);
if(pos!=mid+) return;
node tmp=merge(A[mid],a[k<<],t);
if(tmp[][dir]||tmp[][dir]) pos=l,t=tmp;
else _get_left(l,mid,k<<,pos,t,dir);
}
}
node get_ans(int l,int r,int k,int x,int y){
if(l==x&&r==y) return a[k];
int mid=l+(r-l)/;
if(y<=mid) return get_ans(l,mid,k<<,x,y);
if(x>mid) return get_ans(mid+,r,k<<|,x,y);
return merge(A[mid],get_ans(l,mid,k<<,x,mid),get_ans(mid+,r,k<<|,mid+,y));
}
}t;
void update(int x1,int y1,int x2,int y2,bool op){
if(x1==x2){//r
if(y1>y2) swap(y1,y2);
A[y1][x1]=op;
t.update(,n,,y1,op,false);
}
else t.update(,n,,y1,op,true);//c
}
void query(int x1,int y1,int x2,int y2){
if(y1>y2) swap(x1,x2), swap(y1,y2);
node tmp1;
t.get_left(,n,,y1,tmp1,x1);
x1=tmp1[][x1]?:;
node tmp2;
t.get_right(,n,,y2,tmp2,x2);
x2=tmp2[x2][]?:;
node tmp=t.get_ans(,n,,y1,y2);
puts(tmp[x1][x2]?"Y":"N"); }
int main(){
int x1,y1,x2,y2;
scanf("%d",&n);
t.build_tree(,n,);
while(true){
scanf("%s",s);
if(s[]=='C') scanf("%d%d%d%d",&x1,&y1,&x2,&y2), update(x1-,y1,x2-,y2,false);
else if(s[]=='O') scanf("%d%d%d%d",&x1,&y1,&x2,&y2), update(x1-,y1,x2-,y2,true);
else if(s[]=='A') scanf("%d%d%d%d",&x1,&y1,&x2,&y2), query(x1-,y1,x2-,y2);
else if(s[]=='E') break;
}
return ;
}

1018: [SHOI2008]堵塞的交通traffic

Time Limit: 3 Sec  Memory Limit: 162 MB
Submit: 2747  Solved: 914
[Submit][Status][Discuss]

Description

  有一天,由于某种穿越现象作用,你来到了传说中的小人国。小人国的布局非常奇特,整个国家的交通系统可
以被看成是一个2行C列的矩形网格,网格上的每个点代表一个城市,相邻的城市之间有一条道路,所以总共有2C个
城市和3C-2条道路。 小人国的交通状况非常槽糕。有的时候由于交通堵塞,两座城市之间的道路会变得不连通,
直到拥堵解决,道路才会恢复畅通。初来咋到的你决心毛遂自荐到交通部某份差事,部长听说你来自一个科技高度
发达的世界,喜出望外地要求你编写一个查询应答系统,以挽救已经病入膏肓的小人国交通系统。 小人国的交通
部将提供一些交通信息给你,你的任务是根据当前的交通情况回答查询的问题。交通信息可以分为以下几种格式:
Close r1 c1 r2 c2:相邻的两座城市(r1,c1)和(r2,c2)之间的道路被堵塞了;Open r1 c1 r2 c2:相邻的两座城
市(r1,c1)和(r2,c2)之间的道路被疏通了;Ask r1 c1 r2 c2:询问城市(r1,c1)和(r2,c2)是否连通。如果存在一
条路径使得这两条城市连通,则返回Y,否则返回N;

Input

  第一行只有一个整数C,表示网格的列数。接下来若干行,每行为一条交通信息,以单独的一行“Exit”作为
结束。我们假设在一开始所有的道路都是堵塞的。我们保证 C小于等于100000,信息条数小于等于100000。

Output

  对于每个查询,输出一个“Y”或“N”。

Sample Input

2
Open 1 1 1 2
Open 1 2 2 2
Ask 1 1 2 2
Ask 2 1 2 2
Exit

Sample Output

Y
N

HINT

Source

BZOJ_1018_[SHOI2008]_交通堵塞traffic_(线段树)的更多相关文章

  1. [bzoj1018][SHOI2008]堵塞的交通traffic_线段树

    bzoj-1018 SHOI-2008 堵塞的交通traffic 参考博客:https://www.cnblogs.com/MashiroSky/p/5973686.html 题目大意:有一天,由于某 ...

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

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

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

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

  4. 【BZOJ1018】堵塞的交通traffic(线段树,网格图,连通性)

    题意:一个2行C列的矩形网格图,网格上的每个点代表一个城市,相邻的城市之间有一条道路 一开始每条道路都是堵塞的,堵塞即为不可经过.经过一些操作后,可能某些道路通畅了,也可能某些道路堵塞了 多次询问,询 ...

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

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

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

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

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

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

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

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

  9. BZOJ1018[SHOI2008]堵塞的交通——线段树

    题目描述 有一天,由于某种穿越现象作用,你来到了传说中的小人国.小人国的布局非常奇特,整个国家的交通系统可以被看成是一个2行C列的矩形网格,网格上的每个点代表一个城市,相邻的城市之间有一条道路,所以总 ...

随机推荐

  1. Android图像处理2

    此次实验主要通过Android中的方法获取输入的颜色矩阵的值,更改后赋值给图片中的颜色矩阵更改图片效果.具体的布局的方法跟笔记1种差不多,只不过这里要添加一个供用户输入的GridView <Gr ...

  2. poj 3641 Pseudoprime numbers Miller_Rabin测素裸题

    题目链接 题意:题目定义了Carmichael Numbers 即 a^p % p = a.并且p不是素数.之后输入p,a问p是否为Carmichael Numbers? 坑点:先是各种RE,因为po ...

  3. C语言创建一个窗口提示

    打开Vs2012[我的是2012] /* X下面这些东西并没有什么用... 就不改了用2013 2015都一样 当然 devC++ 还有最原始的那个vc6.0也都是可以的. 编译环境遇到了相关问题网上 ...

  4. 【学习总结】OS X , IOS , IOS SDK , XCode之间的关系

    几个基本的概念 : OS X : 属于桌面PC级别(IMac,MacPro等)对应安装的操作系统 IOS : 属于移动设备级别(Iphone,Ipad等)对应安装的操作系统 XCode: 是一个IDE ...

  5. SpringMVC注解@RequestParam(转)

    鸣谢:http://shawnccx.iteye.com/blog/730239 -------------------------------------------------- 在SpringM ...

  6. [转载]再次谈谈easyui datagrid 的数据加载

    这篇文章只谈jQuery easyui datagrid 的数据加载,因为这也是大家谈论最多的内容.其实easyui datagrid加载数据只有两种方式:一种是ajax加载目标url返回的json数 ...

  7. python参考手册--第4、5、6、7章

    1.zip zip(s,t):将序列组合为一个元组序列[(s[0],t[0]), (s[1],t[1]), (s[2],t[2]), (s[3],t[3]),...] >>> s = ...

  8. Visual Leak Detector 2.2.3 Visual C++内存检测工具

      Visual Leak Detector是一款免费的.健全的.开源的Visual C++内存泄露检测系统.相比Visual C++自带的内存检测机制,Visual Leak Detector可以显 ...

  9. linux mysql数据库安装(tar.gz)

    概述 mysql数据库在linux下可以充分发挥威力,mysql数据库越来越受到软件公司的青睐,为什么呢? 免费.跨平台.轻.支持多并发 在北京很多软件公司属于创业型的中.小公司,从节约成本的角度考虑 ...

  10. <context:component-scan>配置解析(转)

    在xml配置了这个标签后,spring可以自动去扫描base-pack下和其子包下面的java文件,如果扫描到有@Component @Controller@Service等这些注解的类,则把这些类注 ...