1018: [SHOI2008]堵塞的交通traffic

Time Limit: 3 Sec Memory Limit: 162 MB
Submit: 2252 Solved: 711
[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”作为结束。我们假设在一开始所有的道路都是堵塞的。 对30%测试数据,我们保证C小于等于1000,信息条数小于等于1000; 对100%测试数据,我们保证 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

一道用线段树维护连通性的题。
第一做这种题,其实这类问题我们需要维护一下区间内的联通关系,再用我们维护的这些关系去查询。
对于这道题,我觉得可以有两种建树的方法:
①:以每一列为一个叶子节点。
②:以每一个区间(就是每1条横向道路连接的左右两个节点)为一个叶子节点。
我选择的是第一种,我们首先需要维护6个变量(也就是区间内的6种联通关系),分别是luru,ldrd,lurd,ldru,luld,rurd(l:left;r:right;u:up;d:down)
然后由于还有修改横向相邻的道路,所以我们还要维护一个side[]表示这个节点是否可以向外延伸。
最后就是最麻烦的查询了,需要分很多种情况讨论,尤其是当我们查询的这段区间的联通性需要借助它以外的区间才可以联通的这种情况,这些情况就不一一赘述了,具体的看代码吧。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=100100;
struct S{bool luru,ldrd,lurd,ldru,luld,rurd,side[3];}tr[N*4];
char ch[10];
int n,r1,c1,r2,c2;
#define mid (l+r)/2
#define L k<<1,l,mid
#define R k<<1|1,mid+1,r
S update(S x,S y)
{S ans;ans.side[1]=y.side[1];ans.side[2]=y.side[2];ans.luru=ans.ldrd=ans.lurd=ans.ldru=ans.luld=ans.rurd=false;if((x.luru&&x.side[1]&&y.luru)||(x.lurd&&x.side[2]&&y.ldru)) ans.luru=true;if((x.ldrd&&x.side[2]&&y.ldrd)||(x.ldru&&x.side[1]&&y.lurd)) ans.ldrd=true;if((x.luru&&x.side[1]&&y.lurd)||(x.lurd&&x.side[2]&&y.ldrd)) ans.lurd=true;if((x.ldrd&&x.side[2]&&y.ldru)||(x.ldru&&x.side[1]&&y.luru)) ans.ldru=true;if((x.luld)||(x.luru&&x.side[1]&&y.luld&&x.side[2]&&x.ldrd)) ans.luld=true;if((y.rurd)||(y.luru&&x.side[1]&&x.rurd&&x.side[2]&&y.ldrd)) ans.rurd=true;return ans;
}
void build(int k,int l,int r)
{if(l==r){tr[k].luru=tr[k].ldrd=true;return ;}build(L);build(R);tr[k]=update(tr[k<<1],tr[k<<1|1]);
}
void insert_a(int k,int l,int r,int x,bool kind)
{if(l==r){tr[k].luld=tr[k].rurd=tr[k].lurd=tr[k].ldru=kind;return ;}if(x<=mid) insert_a(L,x,kind);else insert_a(R,x,kind);tr[k]=update(tr[k<<1],tr[k<<1|1]);
}
void insert_b(int k,int l,int r,int x,int y,bool kind)
{if(l==r){tr[k].side[y]=kind;return ;}if(x<=mid) insert_b(L,x,y,kind);else insert_b(R,x,y,kind);tr[k]=update(tr[k<<1],tr[k<<1|1]);
}
S query(int k,int l,int r,int x,int y)
{S ans1,ans2;bool left=false,right=false;if(x<=l&&y>=r) return tr[k];if(x<=mid) ans1=query(L,x,y),left=true;if(y>mid) ans2=query(R,x,y),right=true;if(right&&left) return update(ans1,ans2);else return left?ans1:ans2;
}
bool check()
{S now,pre,last;if(c1>c2){swap(r1,r2);swap(c1,c2);}now=query(1,1,n,c1,c2);pre=query(1,1,n,1,c1);last=query(1,1,n,c2,n);if(r1==r2){if((r1==1)&&((now.luru)||(last.luld&&now.lurd)||(pre.rurd&&now.ldru)||(pre.rurd&&now.ldrd&&last.luld))) return true;if((r1==2)&&((now.ldrd)||(last.luld&&now.ldru)||(pre.rurd&&now.lurd)||(pre.rurd&&now.luru&&last.luld))) return true;}else{if((r1==1)&&((now.lurd)||(last.luld&&now.luru)||(pre.rurd&&now.ldrd)||(pre.rurd&&now.ldru&&last.luld))) return true;if((r1==2)&&((now.ldru)||(last.luld&&now.ldrd)||(pre.rurd&&now.luru)||(pre.rurd&&now.lurd&&last.luld))) return true;}return false;
}
int main()
{int i,j;scanf("%d",&n);build(1,1,n);while(scanf("%*c%s",&ch)){if(ch[0]=='E') break;scanf("%d%d%d%d",&r1,&c1,&r2,&c2);if(ch[0]=='O'){if(c1==c2) insert_a(1,1,n,c1,1);else insert_b(1,1,n,min(c1,c2),r1,1);}if(ch[0]=='C'){if(c1==c2) insert_a(1,1,n,c1,0);else insert_b(1,1,n,min(c1,c2),r1,0);}if(ch[0]=='A'){if(check()) printf("Y\n");else printf("N\n");}}
}

【bzoj1018】【SHOI2008】【堵塞的交通traffic】相关推荐

  1. BZOJ1018 [SHOI2008] 堵塞的交通traffic

    @(BZOJ)[线段树] Description 有一天,由于某种穿越现象作用,你来到了传说中的小人国.小人国的布局非常奇特,整个国家的交通系统可 以被看成是一个\(2\)行\(C\)列的矩形网格,网 ...

  2. bzoj1018[SHOI2008]堵塞的交通traffic

    题目链接:bzoj1018 题目大意: 一个2行C列的矩形网格,网格上的每个点代表一个城市,相邻的城市之间有一条道路,所以总共有2C个城市和3C-2条道路. 交通信息可以分为以下几种格式: Close ...

  3. Bzoj1018 [SHOI2008]堵塞的交通traffic

    Time Limit: 3 Sec  Memory Limit: 162 MB Submit: 3458  Solved: 1158 Description 有一天,由于某种穿越现象作用,你来到了传说 ...

  4. BZOJ1018: [SHOI2008]堵塞的交通traffic

    线段树维护每一块左上到左下.右上到右下.左上到右上.左下到右下.左上到右下.左下到右上的联通情况. upd:可以直接用3082的方法搞,能过. #include<bits/stdc++.h> ...

  5. Bzoj1018[SHOI2008]堵塞的交通traffic(线段树)

    这题需要维护连通性,看到有连接删除,很容易直接就想LCT了.然而这题点数20w操作10w,LCT卡常估计过不去.看到这个东西只有两行,考虑能否用魔改后的线性数据结构去维护.我想到了线段树. 考虑如果两 ...

  6. BZOJ 1018: [SHOI2008]堵塞的交通traffic

    二次联通门 : BZOJ 1018: [SHOI2008]堵塞的交通traffic /*BZOJ 1018: [SHOI2008]堵塞的交通traffic麻麻这题玩我这题简直消磨人的意志写了一天了写一 ...

  7. [bzoj1018] [SHOI2008]堵塞的交通

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

  8. [SHOI2008]堵塞的交通traffic

    线段树维护连通性... 通过分析我们可以发现,一个城市到另一个城市一共只有很少的几种情况 所以我们可以维护这个 2*X 矩形 判断其 从左上角到左下角 左上角到右上角 左上角到右下角 左下角到右上角 ...

  9. 【BZOJ】1018: [SHOI2008]堵塞的交通traffic

    http://www.lydsy.com/JudgeOnline/problem.php?id=1018 题意:有2行,每行有c(c<=100000)个城市,则一共有c-1个格子,现在有q(q& ...

  10. BZOJ[1018][SHOI2008]堵塞的交通traffic 线段树

    传送门ber~ 哇这个线段树好神啊!! 用线段树维护图连通性,每个节点开个二维数组 ai,j a i , j a_{i,j}表示这个区间最左面的第 i i i行能不能走到最右面的第j" ro ...

最新文章

  1. Format specifies type 'id' but the argument has type 'NSError *__autoreleasing *
  2. Netty解决粘包和拆包问题的四种方案
  3. Backbone.js源码解读(转载)
  4. 阿里云IoT将举办第三届极客创新挑战赛,吸引全球极客参赛
  5. 百度搜索大数据:“摆摊技巧”搜索热度暴涨655%;中国电信:将逐步关闭3G网络业务;IntelliJ IDEA新版发布|极客头条...
  6. catia装配体怎么把零件旋转180度_各种装配夹具,来看看适合你用的
  7. winform界面嵌入dwg图纸_完美解决窗体中预览DWG图形(C#版)
  8. 5.VMware View 5.0安装与部署-安装view agent与模版
  9. 转:初学shell脚本--shell语法使用
  10. js导出excel(超简单)
  11. iOS简单人脸检测的实现
  12. 三轴传感器、六轴传感器、九轴传感器的文章解读
  13. python+opencv读取文件夹图片并保存
  14. 2022最新u盘升级重装win10方法
  15. HC32F460+RTthread U盘使用详解
  16. 3ds max 2014 启动出现 error while registering plugins 怎么修复
  17. ps 如何使用钢笔工具抠图
  18. 【限流算法】java实现redis分布式时间窗口计数器算法
  19. 卡塔尔世界杯在哪里可以看直播?
  20. 目标追踪与定位学习笔记8-排斥损失:检测人群中的行人

热门文章

  1. 持续打造开放生态圈 华为IT发力地市级市场
  2. SpringBoot实现基础的sso单点登录
  3. 数据安全治理体系建设(内有干货)
  4. 十个CSS3动画工具,你必须收藏!
  5. 灵山奇缘服务器维护,灵山奇缘11月29日每周例行维护公告
  6. python -- (pynsq)
  7. mac安装docker oracle 11g,macOS 使用Docker安装Oracle 11g
  8. 从AI作画到AI做视频,这一跳改变了什么?
  9. openstack介绍及原理
  10. SQLAlchemy - Column详解