题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=3226

题意:初始集合S为空。模拟四种集合操作:集合并、交、差、补集并。

思路:区间有开区间闭区间,首先区间左右都乘以2,这样闭区间在偶数位置,开区间在奇数位置。然后就是区间染色颜色反转两个操作。注意区间染色时,若有反转标记则清除;反转时若有染色标记则直接将染色反转即可。

const int N=70005;

struct node
{
	int L,R;
	int re,color;

	void fill(int c)
	{
		if(re) re=0;
		color=c;
	}

	void reverse()
	{
		if(color!=-1) color^=1;
		else
		{
			re^=1;
		}
	}
};

node a[N<<3];

void build(int t,int L,int R)
{
	a[t].L=L;
	a[t].R=R;
	a[t].color=0;
	a[t].re=0;
	if(L==R) return;
	int M=(L+R)>>1;
	build(t<<1,L,M);
	build(t<<1|1,M+1,R);
}

void pushDown(int t)
{
	if(a[t].L==a[t].R) return;
	if(a[t].color!=-1)
	{
		a[t<<1].fill(a[t].color);
		a[t<<1|1].fill(a[t].color);
		a[t].color=-1;
	}
	if(a[t].re)
	{
		a[t<<1].reverse();
		a[t<<1|1].reverse();
		a[t].re=0;
	}
}

void fill(int t,int L,int R,int c)
{
	if(L>R) return;
	if(a[t].L==L&&a[t].R==R)
	{
		a[t].fill(c);
		return;
	}
	pushDown(t);
	int M=(a[t].L+a[t].R)>>1;
	if(R<=M) fill(t<<1,L,R,c);
	else if(L>M) fill(t<<1|1,L,R,c);
	else
	{
		fill(t<<1,L,M,c);
		fill(t<<1|1,M+1,R,c);
	}
}

void rev(int t,int L,int R)
{
	if(L>R) return;
	if(a[t].L==L&&a[t].R==R)
	{
		a[t].reverse();
		return;
	}
	pushDown(t);
	int M=(a[t].L+a[t].R)>>1;
	if(R<=M) rev(t<<1,L,R);
	else if(L>M) rev(t<<1|1,L,R);
	else
	{
		rev(t<<1,L,M);
		rev(t<<1|1,M+1,R);
	}
};

vector<pair<int,int> > V;

void dfs(int t)
{
	if(a[t].color==1)
	{
		V.pb(MP(a[t].L,a[t].R));
		return;
	}

	if(a[t].color==0) return;
	pushDown(t);
	dfs(t<<1);
	dfs(t<<1|1);
}

int main()
{

	int n=N<<1;
	build(1,0,n);
	char op,ll,rr;
	int l,r;
	while(scanf("%c %c%d,%d%c\n",&op,&ll,&l,&r,&rr)!=-1)
	{
		l<<=1;
		r<<=1;
		if(ll=='(') l++;
		if(rr==')') r--;
		if(op=='U') fill(1,l,r,1);
		else if(op=='I') fill(1,0,l-1,0),fill(1,r+1,n,0);
		else if(op=='D') fill(1,l,r,0);
		else if(op=='C') fill(1,0,l-1,0),fill(1,r+1,n,0),rev(1,l,r);
		else rev(1,l,r);
	}
	dfs(1);
	if(SZ(V)==0)
	{
		puts("empty set");
		return 0;
	}
	int i;
	int tot=SZ(V);
	for(i=0;i<tot-1;i++)
	{
		if(V[i].second+1==V[i+1].first) V[i+1].first=V[i].first;
        else
		{
			if(V[i].first&1) putchar('(');
			else putchar('[');
            printf("%d,%d",V[i].first>>1,V[i].second+1>>1);
            if(V[i].second&1) putchar(')');
            else putchar(']');
            putchar(' ');

        }

	}
	if(V[i].first&1) putchar('(');
	else putchar('[');
	printf("%d,%d",V[i].first>>1,V[i].second+1>>1);
    if(V[i].second&1) putchar(')');
    else putchar(']');
    putchar(' ');
	puts("");
}

BZOJ 3226: [Sdoi2008]校门外的区间的更多相关文章

  1. bzoj 3226 [Sdoi2008]校门外的区间(线段树)

    3226: [Sdoi2008]校门外的区间 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 615  Solved: 227[Submit][Stat ...

  2. 3226. [SDOI2008]校门外的区间【线段树】

    Description   受校门外的树这道经典问题的启发,A君根据基本的离散数学的知识,抽象出5种运算维护集合S(S初始为空)并最终输出S.现在,请你完成这道校门外的树之难度增强版——校门外的区间. ...

  3. 3226: [Sdoi2008]校门外的区间

    链接 思路 bug漫天飞... 维护一颗线段树,支持区间赋值,和区间异或.因为会处理到一些方括号还是圆括号的问题,所以对于每一个下标都乘2,假设中间有一个.5即可,都变成了方括号,输出在处理一下. U ...

  4. BZOJ3226[Sdoi2008]校门外的区间 题解

    题目大意: 有5种运算维护集合S(S初始为空)并最终输出S. 5种运算如下: U T  S∪T I T S∩T D T  S-T C T T-S S T S⊕T 基本集合运算如下: A∪B {x : ...

  5. 「BZOJ3226」[Sdoi2008]校门外的区间

    题目 首先是开闭区间的处理,我们把\(1.5\)这种数加进来,用\([1.5,6]\)来表示\((2,6]\) 根据离散数学的基本知识,尝试把五个操作转化成人话 把\([x,y]\)变成\(1\) 把 ...

  6. [SDOI2008] 校门外的区间 - 线段树

    U T 即将区间 \(T\) 范围赋值为 \(1\) I T 即将区间 \(U - T\) 范围赋值为 \(0\) D T 即将区间 \(T\) 赋值为 \(0\) C T 由于 \(S=T-S=T( ...

  7. BZOJ3226: [Sdoi2008]校门外的区间

    感觉很有趣的题呢. 每个点拆成两个,线段树维护. 不过这题难点其实在输入输出. #include<bits/stdc++.h> #define N (1<<17) #defin ...

  8. [bzoj3226][Sdoi2008]校门外的区间——线段树

    题目 略 题解 直接套黄学长模板. Orz 代码 #include <bits/stdc++.h> using namespace std; #define ll long long #d ...

  9. 【分块】bzoj3226 [Sdoi2008]校门外的区间

    题解见 : http://blog.csdn.net/iamzky/article/details/41088151 ORZ ZKY 2个懒标记:是否翻转,覆盖成了什么. 怎么处理一个块上有两个标记的 ...

随机推荐

  1. logstash5.x改变

    5.x版本 logstash中 elasticsearch插件的workers,无法配置大于1,会提示 This plugin uses the shared and doesn't need thi ...

  2. SpringMVC配制全局的日期格式

    SpringMVC文件配制: <mvc:annotation-driven> <!-- 处理responseBody 里面日期类型 --> <mvc:message-co ...

  3. lower power的IP设计

    在IP的实现过程中,考虑lower power部分进行设计: 1)Partition the design来满足lower power的一些strategies,尤其是power gating和clo ...

  4. OpenCV 简介

    自版本OpenCV2.2开始,OpenCV库便被划分为多个模块.这些模块编译成库文件后,位于lib文件夹中. opencv_core模块,包含核心功能,尤其是底层数据结构和算法函数. opencv_i ...

  5. DB2 表空间和缓冲池

    简介 对于刚涉足 DB2 领域的 DBA 或未来的 DBA 而言,新数据库的设计和性能选择可能会很令人困惑.在本文中,我们将讨论 DBA 要做出重要选择的两个方面:表空间和缓冲池.表空间和缓冲池的设计 ...

  6. mongodb数据库实践笔记

    mongodb 操作规则 从网站上下载安装文件然后在安装目录下创建文件夹data和log创建配置文件mongo.config里面填充如下: ##数据文件dbpath=D:\mongodb\data## ...

  7. Linux内核调试方法总结【转】

    转自:http://my.oschina.net/fgq611/blog/113249 内核开发比用户空间开发更难的一个因素就是内核调试艰难.内核错误往往会导致系统宕机,很难保留出错时的现场.调试内核 ...

  8. Asp.Net Web Api 2 实现多文件打包并下载文件示例源码_转

    一篇关于Asp.Net Web Api下载文件的文章,之前我也写过类似的文章,请见:<ASP.NET(C#) Web Api通过文件流下载文件到本地实例>本文以这篇文章的基础,提供了Byt ...

  9. matlab读入矩阵数据

    方法: 很简单,把矩阵数据存到excel里,然后存成cvs的格式,就是把每行数据之间用‘,’分隔:行与行之间用‘\n’保存. 举例: 假设cvs为test_nnfeature.txt,后缀可以改啦,只 ...

  10. 【转载】perl接受传递参数的方法

    #! /usr/bin/perl use Getopt::Std;use warnings;use strict; sub read_from_sh($) { my $file = shift; my ...