[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; 题解 线段树的又一个骚操 ...
随机推荐
- Python数据类型三
一.帮助 如果想知道一个对象(object)更多的信息,那么可以调用help(object)!另外还有一些有用的方法,dir(object)会显示该对象的大部分相关属性名,还有object._ doc ...
- vlc 编译
一.有用的网址: https://forum.videolan.org/search.php 二.只编译Java apk部分: source env.shmake distcleanmake -e 编 ...
- 二分查找问题(Java版)
二分查找问题(Java版) 1.一般实现 package search; /** * @author lei 2011-8-17 */ public class BinarySearch ...
- Pascal小游戏 随机函数
一个被人写滥了的小程序,新手学习,Pascal By Chaobs 初学者可以用它来学习随机函数的运用,当然你完全可以自己写一个随机函数. var player1,player2:longint; ...
- Selenium+Python自动化之如何绕过登录验证码
一.使用Fiddler抓包 1.一般登陆网站成功后,会生成一个已登录状态的cookie,那么只需要直接把这个值拿到,用selenium进行addCookie操作即可. 2.可以先手动登录一次,然后抓取 ...
- Scrapy爬取到的中文数据乱码问题处理
Scrapy爬取到中文数据默认是 Unicode编码的,于是显示是这样的: "country": ["\u56fd\u4ea7\u6c7d\u8f66\u6807\u5f ...
- php 根据文件内容来判断文件类型
/*文件扩展名说明 *7173 gif *255216 jpg *13780 png *6677 bmp *239187 txt,aspx,asp,sql *208207 xls.doc.ppt *6 ...
- Sprint 站立会议(个人)
昨天做: 开Sprint会议确定并绘制Backlog. 今天做: 系统主窗体格局 编程环境搭建(部分) 遇到问题: 缺乏经验,没有好的总体规划. 团队博客园:http://www.cnblogs.co ...
- c#中onclick事件请求的两种区别
在C#中如果是asp控件的button有两个click的调用,一个是OnClick,一个是OnClientClick.那么这两者有什么区别呢,下面就来说说区别. <asp:Button ID=& ...
- JS计算器(自制)
<!doctype html><html><header><meta charset="utf-8"><script src= ...