【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 有一天,由于某种穿越现象作用,你来到了传说中的小人国.小人国的布局非常奇特,整个国家的交通系统可以被看成是一个 ...
随机推荐
- bzoj 2144: 跳跳棋——倍增/二分
Description 跳跳棋是在一条数轴上进行的.棋子只能摆在整点上.每个点不能摆超过一个棋子.我们用跳跳棋来做一个简单的游戏:棋盘上有3颗棋子,分别在a,b,c这三个位置.我们要通过最少的跳动把他 ...
- bzoj 1014 splay
首先我们可以用splay来维护这个字符串,那么对于某两个位置的lcp,维护每个节点的子树的hash,然后二分判断就好了. /************************************** ...
- 编写jquery Plugin
编写jquery插件的原则 1.给$.fn绑定函数,实现插件的代码逻辑 2.插件函数最后要return this,以支持链式调用 3.插件函数要有默认值,绑定在$.fn.<pluginName& ...
- Python 16进制与字符串的转换
电脑上装了Python2.7和3.3两个版本,平时运行程序包括在Eclipse里面调试都会使用2.7,但是由于某些原因在cmd命令行中输入python得到的解释器则是3.3, 一直没对此做处理,因为这 ...
- windows下常用快捷键(转)
原文转自 https://blog.csdn.net/LJFPHP/article/details/78818696 win+E 打开文件管器 win+D ...
- chromedriver版本 支持的Chrome版本
在使用selenium测试时,如果选择chrome浏览器,需要将chrome driver的exe文件放在项目下 错误的driver版本,会导致无法正常打开本机的浏览器 以下为对应关系 来自网络 ch ...
- 9.quartus_warning_altera_reserved_tck
编译的时候没有注意,整个工程都可以在板子上跑起来.但是做Powerplay的时候,出现了这个Critical Warning:. Critical Warning: The following clo ...
- java===java基础学习(1)---数据类型,运算,变量,常量
今天起开始了java的学习之路,主要学习了数据类型和运算,变量,常量.基本和python有很多相通的地方,所以看起来很容易上手.下面是学习笔记! package testbotoo; public c ...
- 【bzoj1024】生日蛋糕
一开始想dp 后来发现既然要均等,又看了下数据条件 暴力就能做. #include<bits/stdc++.h> using namespace std; ; int x,y,n; dou ...
- Mac 使用自带的Ruby 安装brew
Homebrew简称brew,OSX上的软件包管理工具,在Mac终端可以通过brew安装.更新.卸载软件. 首先要安装brew,在 mac 中使用finder 搜索 终端(terminal)打开命令行 ...