BZOJ 1018 线段树维护图的连通性问题
思路:
我们可以搞一棵线段树
对于一段区间有6种情况需要讨论
左上右下、左上右上、左下右下、左下右上
这四种比较好维护
用左上右下举个例子吧
就是左儿子的左上右下&左区间到右区间下面有路&右儿子的左下右下
或者是左儿子的左上右上&左区间到右区间上面有路&右儿子的左上右下
还有两种 区间的左(右)端点上下能不能联通 需要维护
这种就是左儿子的上下连通或(左上右上&左上右下&左到右两条路都联通&右儿子的上下联通)
(假设c1<c2)
最后要查的是 1->c1 (可以1~c1上下联通再c1[!r1]->c2)
c1->c2(直接联通当然最好)
c2->cn
还有一种是1~c1上下联通&c2~n上下联通&c1[!r1]与c2[!r2]上下联通
4种分类讨论即可
//By SiriusRen
#include <cstdio>
#include <algorithm>
using namespace std;
const int N=;
int map[N][],map2[N],n,r1,c1,r2,c2,jy;
char op[];
struct Node{bool b[][],c[];}tree[N*];
Node push_up(Node L,Node R,int mid){
Node tmp;
tmp.b[][]=(L.b[][]&map[mid][]&R.b[][])|(L.b[][]&map[mid][]&R.b[][]);
tmp.b[][]=(L.b[][]&map[mid][]&R.b[][])|(L.b[][]&map[mid][]&R.b[][]);
tmp.b[][]=(L.b[][]&map[mid][]&R.b[][])|(L.b[][]&map[mid][]&R.b[][]);
tmp.b[][]=(L.b[][]&map[mid][]&R.b[][])|(L.b[][]&map[mid][]&R.b[][]);
tmp.c[]=L.c[]|(L.b[][]&map[mid][]&map[mid][]&L.b[][]&R.c[]);
tmp.c[]=R.c[]|(R.b[][]&map[mid][]&map[mid][]&R.b[][]&L.c[]);
return tmp;
}
void build(int l,int r,int pos){
if(l==r){tree[pos].b[][]=tree[pos].b[][]=;return;}
int mid=(l+r)>>,lson=pos<<,rson=pos<<|;
build(l,mid,lson),build(mid+,r,rson);
}
void insert(int l,int r,int pos,int L,int num,bool v){
if(l==r){
if(num==)tree[pos].b[][]=tree[pos].b[][]=tree[pos].c[]=tree[pos].c[]=map2[l]=v;
else map[l][num]=v;return;
}
int mid=(l+r)>>,lson=pos<<,rson=pos<<|;
if(mid<L)insert(mid+,r,rson,L,num,v);
else insert(l,mid,lson,L,num,v);
tree[pos]=push_up(tree[lson],tree[rson],mid);
}
Node query(int l,int r,int pos,int L,int R){
if(l>=L&&r<=R)return tree[pos];
int mid=(l+r)>>,lson=pos<<,rson=pos<<|;
if(mid<L)return query(mid+,r,rson,L,R);
else if(mid>=R)return query(l,mid,lson,L,R);
else return push_up(query(l,mid,lson,L,R),query(mid+,r,rson,L,R),mid);
}
int main(){
scanf("%d",&n),build(,n,);
while(scanf("%s",op)&&op[]!='E'){
scanf("%d%d%d%d",&r1,&c1,&r2,&c2),r1--,r2--;
if(c1>c2)swap(c1,c2),swap(r1,r2);
if(op[]=='A'){
Node a=query(,n,,,c1),b=query(,n,,c2,n),c=query(,n,,c1,c2);
if(c.b[r1][r2]|(a.c[]&c.b[!r1][r2])|(b.c[]&c.b[r1][!r2])|(b.c[]&a.c[]&c.b[!r1][!r2]))puts("Y");
else puts("N");
}
else{
if(r1==r2)jy=(r1==);
else jy=;
insert(,n,,c1,jy,op[]=='O');
}
}
}
BZOJ 1018 线段树维护图的连通性问题的更多相关文章
- BZOJ 1018 线段树维护图连通性
用8个bool维护即可分别为LURU,LURD,LDRU,LDRD,LULD,RURD,Side[1],Side[2]即可. Side表示这一块有没有接到右边.Merge一下就可以了.码农题,WA了一 ...
- bzoj 1018 线段树维护连通性
本题将一道LCT的题特殊化(支持加边和删边,询问图的连通性),将图变成了2×m的网格图,然后就神奇地可以用线段树来维护. 对于每个区间[l,r],维护其四个角落之间的连通性(仅仅通过[l,r]这段的边 ...
- BZOJ 2124 线段树维护hash值
思路: http://blog.csdn.net/wzq_QwQ/article/details/47152909 (代码也是抄的他的) 自己写得垃圾线段树怎么都过不了 隔了两个月 再写 再挂 又隔了 ...
- bzoj 4127 线段树维护绝对值之和
因为d>=0,所以一个位置的数只会单调不降并且只会有一次穿过0. 用这个性质,我们我可在线段树中记录正数负数的个数和和,以及最大的负数以及答案. 修改操作:如果当前最大负数+d<=0,那么 ...
- BZOJ.1018.[SHOI2008]堵塞的交通(线段树维护连通性)
题目链接 只有两行,可能的路径数不多,考虑用线段树维护各种路径的连通性. 每个节点记录luru(left_up->right_up),lurd,ldru,ldrd,luld,rurd,表示这个区 ...
- [BZOJ 3995] [SDOI2015] 道路修建 【线段树维护连通性】
题目链接:BZOJ - 3995 题目分析 这道题..是我悲伤的回忆.. 线段树维护连通性,与 BZOJ-1018 类似,然而我省选之前并没有做过 1018,即使它在 ProblemSet 的第一页 ...
- [BZOJ 1018] [SHOI2008] 堵塞的交通traffic 【线段树维护联通性】
题目链接:BZOJ - 1018 题目分析 这道题就说明了刷题少,比赛就容易跪..SDOI Round1 Day2 T3 就是与这道题类似的..然而我并没有做过这道题.. 这道题是线段树维护联通性的经 ...
- [BZOJ1018][SHOI2008]堵塞的交通traffic 线段树维护连通性
1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec Memory Limit: 162 MB Submit: 3795 Solved: 1253 [Sub ...
- BZOJ.1036 [ZJOI2008]树的统计Count ( 点权树链剖分 线段树维护和与最值)
BZOJ.1036 [ZJOI2008]树的统计Count (树链剖分 线段树维护和与最值) 题意分析 (题目图片来自于 这里) 第一道树链剖分的题目,谈一下自己的理解. 树链剖分能解决的问题是,题目 ...
随机推荐
- POJ_3020_最小路径覆盖
Antenna Placement Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8721 Accepted: 4330 ...
- react-router @4用法整理
在React Router 3上写了一篇文章后不久,我第一次在React Rally 2016上遇到了Michael Jackson.Michael是React Router和Ryan Florenc ...
- springboot 大致启动流程
SpringApplication的run方法的实现是我们本次旅程的主要线路,该方法的主要流程大体可以归纳如下: 1) 如果我们使用的是SpringApplication的静态run方法,那么,这个方 ...
- luogu P1714 切蛋糕 单调队列
单调队列傻题. 考虑以 $i$ 结尾的答案 : $max(sumv_{i}-sumv_{j}),j \in [i-m,i-1]$ ($sumv_{i}$ 为前缀和) 稍微搞一搞,发现 $sumv_{i ...
- PAT_A1143#Lowest Common Ancestor
Source: PAT A1143 Lowest Common Ancestor (30 分) Description: The lowest common ancestor (LCA) of two ...
- 获取第n天日期
function datezh(s){ return s = s>9 ? s:"0"+s } function dateTime(t){ var getNowTime = v ...
- 家谱(gen)——洛谷P2814
#include <iostream> #include <string> #include <map> using namespace std; map < ...
- 结构体、枚举、联合(day14)
一个存储区的地址必须是它自身大小的整数倍 (double类型存储区的地址只需要是4的 整数倍) 这个规则叫数据对齐 结构体里面的子存储区通常也需要遵守数据 对齐的规则 数据对齐会造成结构体内部子存储区 ...
- SQL中IS NOT NULL与!=NULL的区别
平时经常会遇到这两种写法:IS NOT NULL与!=NULL.也经常会遇到数据库有符合条件!=NULL的数据,但是返回为空集合.实际上,是由于对二者使用区别理解不透彻. 默认情况下,推荐使用 IS ...
- 将现有硬盘(分区)无损创建为RAID1
背景 如果现在有一块硬盘(分区)正在使用,如果要设置成RAID1,并不需要将数据拷出,然后创建RAID1. 可以先将此硬盘设置成降级RAID1,然后添加新硬盘再激活RAID1即可,整个过程数据无损. ...