[BZOJ1018][SHOI2008]堵塞的交通traffic 线段树维护连通性
1018: [SHOI2008]堵塞的交通traffic
Time Limit: 3 Sec Memory Limit: 162 MB Submit: 3795 Solved: 1253 [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
Open 1 1 1 2
Open 1 2 2 2
Ask 1 1 2 2
Ask 2 1 2 2
Exit
Sample Output
N
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
#include<algorithm>
#define MAXN 100005
using namespace std;
int c;
struct data {
int l1l2,l1r1,l1r2,l2r1,l2r2,r1r2;
int b[];
}t[MAXN*]; data pushup(data lc,data rc) {
data ans;
ans.b[]=rc.b[];ans.b[]=rc.b[];
ans.l1l2=ans.l1r1=ans.l1r2=ans.l2r1=ans.l2r2=ans.r1r2=;
if(lc.l1l2||(lc.l1r1&&lc.b[]&&rc.l1l2&&lc.b[]&&lc.l2r2)) ans.l1l2=;
if(rc.r1r2||(rc.l1r1&&lc.b[]&&lc.r1r2&&lc.b[]&&rc.l2r2)) ans.r1r2=;
if((lc.l1r1&&lc.b[]&&rc.l1r1)||(lc.l1r2&&lc.b[]&&rc.l2r1)) ans.l1r1=;
if((lc.l1r1&&lc.b[]&&rc.l1r2)||(lc.l1r2&&lc.b[]&&rc.l2r2)) ans.l1r2=;
if((lc.l2r1&&lc.b[]&&rc.l1r1)||(lc.l2r2&&lc.b[]&&rc.l2r1)) ans.l2r1=;
if((lc.l2r1&&lc.b[]&&rc.l1r2)||(lc.l2r2&&lc.b[]&&rc.l2r2)) ans.l2r2=;
return ans;
} void build(int l,int r,int o) {
if(l==r){t[o].l1r1=t[o].l2r2=;return;}
int mid=(l+r)>>,lc=o<<,rc=lc+;
build(l,mid,lc);build(mid+,r,rc);
t[o]=pushup(t[lc],t[rc]);
}
int l1,r1,l2,r2;
void update_1(int l,int r,int o,int x,int kind) {
if(l==r){t[o].b[l1]=kind;return;}
int mid=(l+r)>>,lc=o<<,rc=lc+;
if(x<=mid) update_1(l,mid,lc,x,kind);
else update_1(mid+,r,rc,x,kind);
t[o]=pushup(t[lc],t[rc]);
} void update_2(int l,int r,int o,int x,int kind) {
if(l==r){t[o].l1l2=t[o].l2r1=t[o].l1r2=t[o].r1r2=kind;return;}
int mid=(l+r)>>,lc=o<<,rc=lc+;
if(x<=mid) update_2(l,mid,lc,x,kind);
else update_2(mid+,r,rc,x,kind);
t[o]=pushup(t[lc],t[rc]);
}
data query(int l,int r,int o,int L,int R) {
if(L<=l&&R>=r){return t[o];}
int mid=(l+r)>>,lc=o<<,rc=lc+;
if(L>mid) {return query(mid+,r,rc,L,R);}
else if(R<=mid){return query(l,mid,lc,L,R);}
else return pushup(query(l,mid,lc,L,R),query(mid+,r,rc,L,R));
}
bool check() {
data l=query(,c,,,r1);
data r=query(,c,,r2,c);
data now=query(,c,,r1,r2);
if(l1==l2) {
if((l1==)&&(now.l1r1||(now.l1r2&&r.l1l2)||(now.l2r1&&l.r1r2)||(now.l2r2&&l.r1r2&&r.l1l2))) return ;
if((l1==)&&(now.l2r2||(now.l2r1&&r.l1l2)||(now.l1r2&&l.r1r2)||(now.l1r1&&l.r1r2&&r.l1l2))) return ;
}
else {
if((l1==)&&(now.l1r2||(now.l1r1&&r.l1l2)||(now.l2r2&&l.r1r2)||(now.l2r1&&l.r1r2&&r.l1l2))) return ;
if((l1==)&&(now.l2r1||(now.l2r2&&r.l1l2)||(now.l1r1&&l.r1r2)||(now.l1r2&&l.r1r2&&r.l1l2))) return ;
}
return ;
}
int main() {
//freopen("data.in","r",stdin);
//freopen("2.out","w",stdout);
scanf("%d",&c);
build(,c,);
while() {
char ch[];
scanf("%s",ch);
if(ch[]=='O') {
scanf("%d%d%d%d",&l1,&r1,&l2,&r2);
if(r1>r2){swap(l1,l2);swap(r1,r2);}
if(r1!=r2) update_1(,c,,r1,);
else update_2(,c,,r1,);
}
else if(ch[]=='C') {
scanf("%d%d%d%d",&l1,&r1,&l2,&r2);
if(r1>r2){swap(l1,l2);swap(r1,r2);}
if(r1!=r2) update_1(,c,,r1,);
else update_2(,c,,r1,);
}
else if(ch[]=='A') {
scanf("%d%d%d%d",&l1,&r1,&l2,&r2);
if(r1>r2){swap(l1,l2);swap(r1,r2);}
if(check()) printf("Y\n");
else printf("N\n");
}
else return ;
}
}
[BZOJ1018][SHOI2008]堵塞的交通traffic 线段树维护连通性的更多相关文章
- Bzoj1018[SHOI2008]堵塞的交通traffic(线段树)
这题需要维护连通性,看到有连接删除,很容易直接就想LCT了.然而这题点数20w操作10w,LCT卡常估计过不去.看到这个东西只有两行,考虑能否用魔改后的线性数据结构去维护.我想到了线段树. 考虑如果两 ...
- bzoj1018[SHOI2008]堵塞的交通traffic——线段树
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1018 巧妙的线段树.维护矩阵四个角的连通性. 考虑两个点连通的可能路径分成3部分:两点左边. ...
- [bzoj1018][SHOI2008]堵塞的交通traffic_线段树
bzoj-1018 SHOI-2008 堵塞的交通traffic 参考博客:https://www.cnblogs.com/MashiroSky/p/5973686.html 题目大意:有一天,由于某 ...
- 【BZOJ1018】[SHOI2008]堵塞的交通traffic 线段树
[BZOJ1018][SHOI2008]堵塞的交通traffic Description 有一天,由于某种穿越现象作用,你来到了传说中的小人国.小人国的布局非常奇特,整个国家的交通系统可以被看成是一个 ...
- BZOJ 1018: [SHOI2008]堵塞的交通traffic [线段树 区间信息]
1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 3064 Solved: 1027[Submi ...
- BZOJ1018 SHOI2008堵塞的交通(线段树)
动态图的连通性当然是可以用LCT维护的.但这相当的不优美,毕竟这样做没有用到任何该图的性质,LCT自带的大常数也会使其跑得非常慢. 考虑用线段树维护区间左右端四个点之间各自的连通性(仅经过该区间内路径 ...
- 【bzoj1018】[SHOI2008]堵塞的交通traffic 线段树区间合并+STL-set
题目描述 给出一张2*n的网格图,初始每条边都是不连通的.多次改变一条边的连通性或询问两个点是否连通. 输入 第一行只有一个整数C,表示网格的列数.接下来若干行,每行为一条交通信息,以单独的一行“Ex ...
- BZOJ 1018: [SHOI2008]堵塞的交通traffic(线段树分治+并查集)
传送门 解题思路 可以离线,然后确定每个边的出现时间,算这个排序即可.然后就可以线段树分治了,连通性用并查集维护,因为要撤销,所以要按秩合并,时间复杂度\(O(nlog^2 n)\) 代码 #incl ...
- [SHOI2008]堵塞的交通(线段树维护联通性)
题目 2行c列个点,开始时互不联通,支持给同一列或着同一行相邻的两个点连边,和询问两个点能否在一个联通块里. 1≤C≤100000 1<=操作数<=100000; 题解 线段树的又一个骚操 ...
随机推荐
- ElasticSearch学习笔记(二)-- mapping
1. mapping简介 2. 自定义 mapping 3. mapping演示 创建索引,设置mapping,可以新增字段 get一下mapping 设置索引的字段不可新增 为索引添加字段,发现报错 ...
- ScrollView中ViewPager无法正常滑动问题
本文主要介绍如何解决ViewPager在ScrollView中滑动经常失效.无法正常滑动问题. 解决方法只需要在接近水平滚动时ScrollView不处理事件而交由其子View(即这里的ViewPage ...
- USACO Section1.4 Mother's Milk 解题报告
milk3解题报告 —— icedream61 博客园(转载请注明出处)---------------------------------------------------------------- ...
- 六 APPIUM Android 定位方式
文本转自:http://www.cnblogs.com/sundalian/p/5629500.html APPIUM Android 定位方式 1.定位元素应用元素 1.1通过id定位元素 An ...
- SPOJ - DQUERY(区间不同数+树状数组)
链接:SPOJ - DQUERY 题意:求给定区间不同数的个数(不更新). 题解:离线+树状数组. 对所求的所有区间(l, r)根据r从小到大排序.从1-n依次遍历序列数组,在树状数组中不断更新a[i ...
- c++知识点总结--new的一些用法
new operator 将对象产生与heap,不但分配内存而且为该对象调用一个constructor operator new只是分配内存,没有constructor被调用 有个一个特殊版本,称 ...
- STL之算法使用简介
accumlate : iterator 对标志的序列中的元素之和,加到一个由 init 指定的初始值上.重载的版本不再做加法,而是传进来的二元操作符被应用到元素上. adjacent_differ ...
- HTML5应用:setCustomValidity(message)接口
本文转自http://tid.tenpay.com/?p=3592 HTML5表单验证给前端人员带来了便利,但是在用户体验上存在一些缺陷,默认的提示对用户很不友好,无法准确的获取想要的信息.好在大牛们 ...
- 软工实践Beta冲刺前装备
过去存在的问题 组员之间缺乏沟通,前后端缺乏沟通协作 组员积极性不高 基础知识不够扎实 手动整合代码效率过低 我们已经做了哪些调整/改进 通过会议加强组员之间的交流 组长请喝了奶茶提高大家积极性 努力 ...
- struct&&class 空的大小
#include using namespace std; class ClassA { }; class ClassB { private: int b; }; class ClassC : pub ...