[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; 题解 线段树的又一个骚操 ...
随机推荐
- laravel5.5任务调度
目录 1. 定义调度 1.1 使用Closure 1.2 Artisan 命令调度 1.3 队列任务调度 1.4 Shell 命令调度 1.5 调度频率设置 1.6 闭包测试限制 1.7 避免任务重复 ...
- Spring自动装配bean
Spring推荐面向接口编程,这样可以很好的解耦具体的实现类. CompactDisc.class 文件: public interface CompactDisc { void play(); } ...
- LC.exe已退出,代码为-1
解决方法就是把Properties文件下的license.licx给删除,重新编译,这样就可以了.
- ICG-智能代码生成器.(权限控制.融入平台).(表单引擎).(最低兼容IE8)
请下拉滚动条... 代码生成器.附带客户端代码 个人平台:www.10086bank.com 界面: 1--首先是server制作界面(BS结构).直接上图: 2--点击提交生成一下文件: 各个代 ...
- CTF python沙箱逃逸进阶题目
future引用了python3的新特性,所以是不能直接回回显,得用print file函数可以读取. print(().__class__.__bases__[0].__subclasses__() ...
- Jmeter beanshell preprocessor随机添加任意多个请求参数
介绍下本次使用beanshell preprocessor的原因: 1.系统下可添加产品,一个产品可以有多个产品主题(比如:产品A(杭州三日游)拥有三个主题(研学.红学.夏令营)),我们在每次添加产品 ...
- 孤荷凌寒自学python第五十三天使用python写入和修改Firebase数据库中记录
孤荷凌寒自学python第五十三天使用python写入和修改Firebase数据库中记录 (完整学习过程屏幕记录视频地址在文末) 今天继续研究Firebase数据库,利用google免费提供的这个数 ...
- Leetcode 670.最大交换
最大交换 给定一个非负整数,你至多可以交换一次数字中的任意两位.返回你能得到的最大值. 示例 1 : 输入: 2736 输出: 7236 解释: 交换数字2和数字7. 示例 2 : 输入: 9973 ...
- 巧用Fiddler代理来禁止资源缓存,从而达到每次都是从服务器加载最新的资源
Fiddler -> Rules -> Performance -> Disable Caching 直接设置禁用缓存,再在没有清除缓存功能的APP 中重新加载最新的页面, 每 ...
- PB数据窗口中的几种状态及应用
数据窗口的状态主要有以下几种: 1)New! 2)NewModified! 3)DataModified! 4)NotModified! 数据窗口可以利用这些状态标志判断数据是否被修改过. 记录和字段 ...