【BZOJ 1018】【SHOI 2008】堵塞的交通traffic
http://www.lydsy.com/JudgeOnline/problem.php?id=1018
线段树维护连通性。
把每一列看成一个节点,对于线段树上的每一个节点,维护8个信息,前6个字面意思很好理解,sd0和sd1分别代表这个节点所代表的列区间的最右端再往右的第1/2行是否有道路连出去。
注意一个节点上的信息表示只用这个节点所代表区间内的边是否连通,这样单点修改后再维护一下信息是可行的。
对于询问,因为每个节点维护的信息只是区间内部的边的连通性,所以要查询\(\left[1,c_1\right],\left[c_1,c_2\right],\left[c_2,n\right],c_1\leq c_2\) 3个区间的连通性,暴力分类讨论一下就可以了。
注意分类讨论一定要全面qwq,尤其是不在\(\left[c_1,c_2\right]\)内的边对左右端点的列的上下两行的连通性造成干扰时,\(\left[c_1,c_2\right]\)内的连通性受到的影响非常大,就需要十分严格的分类讨论。
时间复杂度\(O(n\log n)\)。
我的常数好大啊qwq
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = 100003;
struct node {
bool luru, lurd, ldru, ldrd, luld, rurd, sd0, sd1;
void clear() {luru = lurd = ldru = ldrd = luld = rurd = sd0 = sd1 = false;}
void init() {luru = ldrd = sd0 = sd1 = true;}
void copy(node *r) {luru = r->luru; lurd = r->lurd; ldru = r->ldru; ldrd = r->ldrd; luld = r->luld; rurd = r->rurd; sd0 = r->sd0; sd1 = r->sd1;}
} T[N << 2], q1, q2, q3, q4;
int n, r1, c1, r2, c2;
void pushup(node *r, node *c0, node *c1) {
r->sd0 = c1->sd0; r->sd1 = c1->sd1;
r->luru = (c0->luru && c1->luru && c0->sd0 || c0->lurd && c1->ldru && c0->sd1);
r->lurd = (c0->luru && c1->lurd && c0->sd0 || c0->lurd && c1->ldrd && c0->sd1);
r->ldru = (c0->ldru && c1->luru && c0->sd0 || c0->ldrd && c1->ldru && c0->sd1);
r->ldrd = (c0->ldru && c1->lurd && c0->sd0 || c0->ldrd && c1->ldrd && c0->sd1);
r->luld = (c0->luld || c0->sd0 && c0->sd1 && c0->luru && c0->ldrd && c1->luld);
r->rurd = (c1->rurd || c0->sd0 && c0->sd1 && c1->luru && c1->ldrd && c0->rurd);
}
void BuildTree(int rt, int l, int r) {
if (l == r) {T[rt].luru = T[rt].ldrd = true; return;}
int mid = (l + r) >> 1;
BuildTree(rt << 1, l, mid);
BuildTree(rt << 1 | 1, mid + 1, r);
pushup(T + rt, T + (rt << 1), T + (rt << 1 | 1));
}
void update(int rt, int l, int r, int pos, int flag) {
if (l == r) {
switch (flag) {
case -3: T[rt].luld = T[rt].rurd = T[rt].lurd = T[rt].ldru = false; break;
case 3: T[rt].luld = T[rt].rurd = T[rt].lurd = T[rt].ldru = true; break;
case -2: T[rt].sd1 = false; break;
case -1: T[rt].sd0 = false; break;
case 2: T[rt].sd1 = true; break;
case 1: T[rt].sd0 = true; break;
}
return;
}
int mid = (l + r) >> 1;
if (pos <= mid) update(rt << 1, l, mid, pos, flag);
else update(rt << 1 | 1, mid + 1, r, pos, flag);
pushup(T + rt, T + (rt << 1), T + (rt << 1 | 1));
}
void merge(int rt, int l, int r, int L, int R, node *rr) {
if (L <= l && r <= R) {pushup(&q4, rr, T + rt); rr->copy(&q4); return;}
int mid = (l + r) >> 1;
if (L <= mid) merge(rt << 1, l, mid, L, R, rr);
if (R > mid) merge(rt << 1 | 1, mid + 1, r, L, R, rr);
}
bool check() {
if (c1 > c2) {swap(r1, r2); swap(c1, c2);}
q1.clear(); q2.clear(); q3.clear();
q1.init(); q2.init(); q3.init();
merge(1, 1, n, 1, c1, &q1);
merge(1, 1, n, c1, c2, &q2);
merge(1, 1, n, c2, n, &q3);
if (q1.rurd) q2.luld = true; if (q3.luld) q2.rurd = true;
if (q2.luld && q2.ldru || q2.rurd && q2.lurd || q2.luld && q2.rurd && q2.ldrd) q2.luru = true;
if (q2.luld && q2.lurd || q2.rurd && q2.ldru || q2.luld && q2.rurd && q2.luru) q2.ldrd = true;
if (q2.luld && q2.ldrd || q2.rurd && q2.luru || q2.luld && q2.rurd && q2.ldru) q2.lurd = true;
if (q2.luld && q2.luru || q2.rurd && q2.ldrd || q2.luld && q2.rurd && q2.lurd) q2.ldru = true;
if (r1 == 1 && r2 == 1) return q2.luru;
if (r1 == 1 && r2 == 2) return q2.lurd;
if (r1 == 2 && r2 == 1) return q2.ldru;
if (r1 == 2 && r2 == 2) return q2.ldrd;
}
char op[23];
int main() {
scanf("%d", &n);
BuildTree(1, 1, n);
int tt = 0;
while (true) {
scanf("%s", op);
if (op[0] == 'E') break;
scanf("%d%d%d%d", &r1, &c1, &r2, &c2);
switch (op[0]) {
case 'C':
if (c1 == c2) update(1, 1, n, c1, -3);
else update(1, 1, n, min(c1, c2), -r1);
break;
case 'O':
if (c1 == c2) update(1, 1, n, c1, 3);
else update(1, 1, n, min(c1, c2), r1);
break;
case 'A':
puts(check() ? "Y" : "N");
break;
}
}
return 0;
}
【BZOJ 1018】【SHOI 2008】堵塞的交通traffic的更多相关文章
- 【BZOJ 1018】 [SHOI2008]堵塞的交通traffic
[题目链接]:http://www.lydsy.com/JudgeOnline/problem.php?id=1018 [题意] [题解] 按照这里的题解写的http://blog.csdn.net/ ...
- 【BZOJ】【1018】【SHOI2008】堵塞的交通traffic
线段树 这题的线段树+分类讨论蛮神奇的……我以前学的线段树简直就是渣渣QAQ 看了下ydc题解里的思想>_>用线段树维护连通性!那么就自己写吧……每个节点表示一段区间的连通性(我的叶子节点 ...
- 数据结构(线段树):BZOJ 1018: [SHOI2008]堵塞的交通traffic
1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 2638 Solved: 864 Descri ...
- BZOJ 1018 [SHOI2008]堵塞的交通traffic
1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 2247 Solved: 706[Submit ...
- BZOJ 1018: [SHOI2008]堵塞的交通traffic [线段树 区间信息]
1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 3064 Solved: 1027[Submi ...
- bzoj千题计划108:bzoj1018: [SHOI2008]堵塞的交通traffic
http://www.lydsy.com/JudgeOnline/problem.php?id=1018 关键点在于只有两行 所以一个2*m矩形连通情况只有6种 编号即对应代码中的a数组 线段树维护 ...
- 1018: [SHOI2008]堵塞的交通traffic
1018: [SHOI2008]堵塞的交通traffic 链接 分析: 用线段树维护区间的四个端点的联通情况,然后查询的时候,把所有覆盖到的区间合并起来即可. 六种情况左上到右上(左边到右边的情况)… ...
- 【bzoj1018】[SHOI2008]堵塞的交通traffic
1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 2887 Solved: 954[Submit ...
- [BZOJ1018][SHOI2008]堵塞的交通traffic 线段树维护连通性
1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec Memory Limit: 162 MB Submit: 3795 Solved: 1253 [Sub ...
- 【BZOJ1018】[SHOI2008]堵塞的交通traffic 线段树
[BZOJ1018][SHOI2008]堵塞的交通traffic Description 有一天,由于某种穿越现象作用,你来到了传说中的小人国.小人国的布局非常奇特,整个国家的交通系统可以被看成是一个 ...
随机推荐
- CCD和CMOS的差别
单从感光器电子技术上来说,CCD比CMOS更先进,理论成像上有优势,但是最近几年CMOS却发展更好,使得很多高端数码单反采用CMOS传感器,下面来看看CCD和CMOS的技术知识: CCD和CMOS传感 ...
- javascript 事件知识集锦
1.事件委托极其应用 转载的链接: http://www.webhek.com/event-delegate/#comments 2. 解析javascript事件机制 转载链接: http: ...
- Android跳转到拨打电话的页面
在Android6.0之后,拨打电话需要用户授予动态权限,项目中有此需求,有一种简单的方法,直接携带电话号码跳转到系统拨打电话的页面,很多应用也是这么做的,这样可以减轻工作量 代码如下: Androi ...
- ie8下input文字偏上select文字偏下
1.ie8下input文字偏上 正常情况下input的显示情况如下 当设置input的高度时,就会出现文字不垂直居中偏上的情况,如图 解决方案 强input的行高line-height与其高度设置一致 ...
- 【Python学习笔记】Pandas库之DataFrame
1 简介 DataFrame是Python中Pandas库中的一种数据结构,它类似excel,是一种二维表. 或许说它可能有点像matlab的矩阵,但是matlab的矩阵只能放数值型值(当然matla ...
- 玩转excel===Excel处理txt文件中的数据,Excel中的分列处理
我的txt文件数据是这样的,目标是用第一列的数据生成图表: 现在我需要拿到pss列,用Excel的操作如下,先用Excel打开txt文档 所有数据都在A列,单独拿出来第一列数字.这时候要选择分列: o ...
- 2017多校第7场 HDU 6121 Build a tree K叉树,思维
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6121 题意:一个n个点的完全k叉树,求每个节点的size的异或和. 解法:容易发现,考虑根的所有孩子, ...
- how to create view (windows)
View Server List IP address: 200.xx.xx.xx How to create a new view ssh new view server by your Unix ...
- leetcode 之Remove Duplicates from Sorted List(17)
很简单的一题,需要注意的是如果某结点重复了记得将其删除. ListNode *deleteDuplicates(ListNode *head) { if (head == nullptr) retur ...
- 6:django 通用视图
上一节我们介绍了django视图函数里面几个常用的函数,这节我们来看一下django为我们提供的一些通用视图吧 在最后面有我自己的示例代码,html部分太多了就不贴了 “简单”视图函数 正如名字所言, ...