动态图的连通性当然是可以用LCT维护的。但这相当的不优美,毕竟这样做没有用到任何该图的性质,LCT自带的大常数也会使其跑得非常慢。

  考虑用线段树维护区间左右端四个点之间各自的连通性(仅经过该区间内路径)。查询时考虑几种绕来绕去的情况。

  剩下的是大讨论。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std;
int read()
{
int x=,f=;char c=getchar();
while (c<''||c>'') {if (c=='-') f=-;c=getchar();}
while (c>=''&&c<='') x=(x<<)+(x<<)+(c^),c=getchar();
return x*f;
}
#define N 100010
int n;
bool r[N][];
struct data{int L,R;bool f[],w[];//0 u 1 d 2 l 3 r 4 z 5 f
}tree[N<<];
int whichop(int x,int y,int u,int v)
{
if (y==v) return ;
if (x==u) return x;
return x==?:;
}
void build(int k,int l,int r)
{
tree[k].L=l,tree[k].R=r;
if (l==r) {tree[k].f[]=tree[k].f[]=;return;}
else tree[k].w[]=tree[k].w[]=;
int mid=l+r>>;
build(k<<,l,mid);
build(k<<|,mid+,r);
}
data merge(data x,data y)
{
data v;v.L=x.L,v.R=y.R;
v.w[]=x.w[]||y.w[]||!r[x.R][];
v.w[]=x.w[]||y.w[]||!r[x.R][];
v.f[]=x.f[]&&y.f[]&&r[x.R][]||x.f[]&&y.f[]&&r[x.R][];
v.f[]=x.f[]&&y.f[]&&r[x.R][]||x.f[]&&y.f[]&&r[x.R][];
v.f[]=x.f[]||x.f[]&&r[x.R][]&&r[x.R][]&&y.f[];
v.f[]=y.f[]||y.f[]&&r[x.R][]&&r[x.R][]&&x.f[];
v.f[]=x.f[]&&r[x.R][]&&y.f[]||x.f[]&&r[x.R][]&&y.f[];
v.f[]=x.f[]&&r[x.R][]&&y.f[]||x.f[]&&r[x.R][]&&y.f[];
return v;
}
void modifyrow(int k,int x)
{
if (tree[k].L==tree[k].R) return;
if (tree[k].L+==tree[k].R) {tree[k]=merge(tree[k<<],tree[k<<|]);return;}
int mid=tree[k].L+tree[k].R>>;
if (x<mid) modifyrow(k<<,x);
else if (x>mid) modifyrow(k<<|,x);
tree[k]=merge(tree[k<<],tree[k<<|]);
}
void modifyline(int k,int x,int op)
{
if (tree[k].L==tree[k].R)
{
tree[k].f[]=tree[k].f[]=;
tree[k].f[]=tree[k].f[]=tree[k].f[]=tree[k].f[]=op;
return;
}
int mid=tree[k].L+tree[k].R>>;
if (x<=mid) modifyline(k<<,x,op);
else modifyline(k<<|,x,op);
tree[k]=merge(tree[k<<],tree[k<<|]);
}
data query(int k,int l,int r)
{
if (tree[k].L==l&&tree[k].R==r) return tree[k];
int mid=tree[k].L+tree[k].R>>;
if (r<=mid) return query(k<<,l,r);
else if (l>mid) return query(k<<|,l,r);
else return merge(query(k<<,l,mid),query(k<<|,mid+,r));
}
bool isempty(int k,int L,int R,int x)
{
if (tree[k].L==L&&tree[k].R==R) return !tree[k].w[x];
int mid=tree[k].L+tree[k].R>>;
if (R<=mid) return isempty(k<<,L,R,x);
else if (L>mid) return isempty(k<<|,L,R,x);
else return r[tree[k<<].R][x]&&isempty(k<<,L,mid,x)&&isempty(k<<|,mid+,R,x);
}
int queryleft(int k,int p,int x)
{
if (tree[k].L==tree[k].R) return tree[k].L;
int mid=tree[k].L+tree[k].R>>;
if (p<=mid) return queryleft(k<<,p,x);
else return isempty(k<<|,tree[k<<|].L,p,x)&&r[tree[k<<].R][x]?queryleft(k<<,tree[k<<].R,x):queryleft(k<<|,p,x);
}
int queryright(int k,int p,int x)
{
if (tree[k].L==tree[k].R) return tree[k].L;
int mid=tree[k].L+tree[k].R>>;
if (p<=mid) return isempty(k<<,p,tree[k<<].R,x)&&r[tree[k<<].R][x]?queryright(k<<|,tree[k<<|].L,x):queryright(k<<,p,x);
else return queryright(k<<|,p,x);
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("bzoj1018.in","r",stdin);
freopen("bzoj1018.out","w",stdout);
const char LL[]="%I64d\n";
#else
const char LL[]="%lld\n";
#endif
n=read();
build(,,n);
char c=getchar();while (c<'A'||c>'Z') c=getchar();
while (c!='E')
{
int x=read(),y=read(),u=read(),v=read();
if (y>v) swap(x,u),swap(y,v);x--,u--;
if (c=='O')
{
if (y==v) modifyline(,y,);
else r[y][x]=,modifyrow(,y);
}
else if (c=='C')
{
if (y==v) modifyline(,y,);
else r[y][x]=,modifyrow(,y);
}
else
{
y=queryleft(,y,x);
v=queryright(,v,u);
printf(query(,y,v).f[whichop(x,y,u,v)]?"Y\n":"N\n");
}
c=getchar();while (c<'A'||c>'Z') c=getchar();
}
return ;
}

BZOJ1018 SHOI2008堵塞的交通(线段树)的更多相关文章

  1. BZOJ1018[SHOI2008]堵塞的交通——线段树

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

  2. Luogu P4246 [SHOI2008]堵塞的交通(线段树+模拟)

    P4246 [SHOI2008]堵塞的交通 题意 题目描述 有一天,由于某种穿越现象作用,你来到了传说中的小人国.小人国的布局非常奇特,整个国家的交通系统可以被看成是一个\(2\)行\(C\)列的矩形 ...

  3. bzoj1018/luogu4246 堵塞的交通 (线段树)

    对于一个区间四个角的点,可以用线段树记下来它们两两的联通情况 区间[l,r]通过两个子区间[l,m],[m+1,r]来更新,相当于合并[l,m],[m+1,r],用(m,m+1)这条边来合并 查询a, ...

  4. BZOJ.1018.[SHOI2008]堵塞的交通(线段树维护连通性)

    题目链接 只有两行,可能的路径数不多,考虑用线段树维护各种路径的连通性. 每个节点记录luru(left_up->right_up),lurd,ldru,ldrd,luld,rurd,表示这个区 ...

  5. [bzoj1018][SHOI2008]堵塞的交通traffic_线段树

    bzoj-1018 SHOI-2008 堵塞的交通traffic 参考博客:https://www.cnblogs.com/MashiroSky/p/5973686.html 题目大意:有一天,由于某 ...

  6. [BZOJ1018][SHOI2008]堵塞的交通traffic 线段树维护连通性

    1018: [SHOI2008]堵塞的交通traffic Time Limit: 3 Sec  Memory Limit: 162 MB Submit: 3795  Solved: 1253 [Sub ...

  7. bzoj千题计划108:bzoj1018: [SHOI2008]堵塞的交通traffic

    http://www.lydsy.com/JudgeOnline/problem.php?id=1018 关键点在于只有两行 所以一个2*m矩形连通情况只有6种 编号即对应代码中的a数组 线段树维护 ...

  8. 【离线 撤销并查集 线段树分治】bzoj1018: [SHOI2008]堵塞的交通traffic

    本题可化成更一般的问题:离线动态图询问连通性 当然可以利用它的特殊性质,采用在线线段树维护一些标记的方法 Description 有一天,由于某种穿越现象作用,你来到了传说中的小人国.小人国的布局非常 ...

  9. 【线段树】bzoj1018 [SHOI2008]堵塞的交通traffic

    线段树的每个叶子节点存一列. 每个节点维护六个域,分别是左上左下.左上右上.左上右下.左下右上.左下右下.右上右下在区间内部的连通性,不考虑绕出去的情况. 初始每个叶子的左上左下.右上右下是连通的. ...

随机推荐

  1. pstack 故障排除思路

    1.先使用top看下CPU占用高的进程,找出进程的进程ID(pid): 查看方法:top 2.根据进程ID(pid)查看是进程的那些线程占用CPU高. 查看方法:top -Hp pid3.使用psta ...

  2. A Theoretical Analysis of Feature Pooling in Visual Recognition

    这篇是10年ICML的论文,但是它是从原理上来分析池化的原因,因为池化的好坏的确会影响到结果,比如有除了最大池化和均值池化,还有随机池化等等,在eccv14中海油在顶层加个空间金字塔池化的方法.可谓多 ...

  3. js 深复制一个对象

    自定义 cloneObj 方法 //深复制对象 var cloneObj = function (obj) { var newObj = {}; if (obj instanceof Array) { ...

  4. SonarQube-Centos环境设置为系统服务

    1.准备工作 官方文档:https://docs.sonarqube.org/latest/setup/operate-server/ 2.配置 /sonar.sh /usr/bin/sonar cd ...

  5. mysql事务,select for update,及数据的一致性处理

    在MySQL的InnoDB中,预设的Tansaction isolation level 为REPEATABLE READ(可重读) 在SELECT 的读取锁定主要分为两种方式: SELECT ... ...

  6. python基础——类定义(转)

    一.类定义: class <类名>: <语句> 类实例化后,可以使用其属性,实际上,创建一个类之后,可以通过类名访问其属性.如果直接使用类名修改其属性,那么将直接影响到已经实例 ...

  7. 【Qt】QLabel实现的圆形图像

    本篇只描述圆形图像的两种实现方式,动态阴影边框如下: [Qt]QLabel之动态阴影边框 目前实现的效果如下: 左右两边实现的方式不同: 右边比较简单 min-width: 100px; max-wi ...

  8. 使用python处理百万条数据分享(适用于java新手)

    1.前言 因为负责基础服务,经常需要处理一些数据,但是大多时候采用awk以及java程序即可,但是这次突然有百万级数据需要处理,通过awk无法进行匹配,然后我又采用java来处理,文件一分为8同时开启 ...

  9. Asp.Net_抓包解析xml文件为json

    protected void Button1_Click(object sender, EventArgs e) { string Phone = this.Txt_Con.Text; string ...

  10. python + selenium webdriver 自动化测试 之 环境异常处理 (持续更新)

    1.webdriver版本与浏览器版本不匹配,在执行的时候会抛出如下错误提示 selenium.common.exceptions.WebDriverException: Message: unkno ...