BZOJ 3226: [Sdoi2008]校门外的区间
题目链接: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]校门外的区间的更多相关文章
- bzoj 3226 [Sdoi2008]校门外的区间(线段树)
3226: [Sdoi2008]校门外的区间 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 615 Solved: 227[Submit][Stat ...
- 3226. [SDOI2008]校门外的区间【线段树】
Description 受校门外的树这道经典问题的启发,A君根据基本的离散数学的知识,抽象出5种运算维护集合S(S初始为空)并最终输出S.现在,请你完成这道校门外的树之难度增强版——校门外的区间. ...
- 3226: [Sdoi2008]校门外的区间
链接 思路 bug漫天飞... 维护一颗线段树,支持区间赋值,和区间异或.因为会处理到一些方括号还是圆括号的问题,所以对于每一个下标都乘2,假设中间有一个.5即可,都变成了方括号,输出在处理一下. U ...
- 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 : ...
- 「BZOJ3226」[Sdoi2008]校门外的区间
题目 首先是开闭区间的处理,我们把\(1.5\)这种数加进来,用\([1.5,6]\)来表示\((2,6]\) 根据离散数学的基本知识,尝试把五个操作转化成人话 把\([x,y]\)变成\(1\) 把 ...
- [SDOI2008] 校门外的区间 - 线段树
U T 即将区间 \(T\) 范围赋值为 \(1\) I T 即将区间 \(U - T\) 范围赋值为 \(0\) D T 即将区间 \(T\) 赋值为 \(0\) C T 由于 \(S=T-S=T( ...
- BZOJ3226: [Sdoi2008]校门外的区间
感觉很有趣的题呢. 每个点拆成两个,线段树维护. 不过这题难点其实在输入输出. #include<bits/stdc++.h> #define N (1<<17) #defin ...
- [bzoj3226][Sdoi2008]校门外的区间——线段树
题目 略 题解 直接套黄学长模板. Orz 代码 #include <bits/stdc++.h> using namespace std; #define ll long long #d ...
- 【分块】bzoj3226 [Sdoi2008]校门外的区间
题解见 : http://blog.csdn.net/iamzky/article/details/41088151 ORZ ZKY 2个懒标记:是否翻转,覆盖成了什么. 怎么处理一个块上有两个标记的 ...
随机推荐
- linux系统-代码行数计算
find macc-cometd -type f -name "*.java" -print0 | xargs -0 wc -l
- 夺命雷公狗---DEDECMS----23dedecms修改内容页面展示的信息
我们在网站上不管点击那个影视作品的A连接都是进入到一个同样的页面,因为他们是一个模版文件: 我们还没有对这个模版进行任何的修改,所以我们要在内容模版增加标签取出对应的影视作品,而且导航条也是按照模版上 ...
- ADIv5.2
ADI:ARM Debug Interface,出到现在共有五代: 1)version1 and version 2:只针对ARM7TDMI和ARM9的processor: 2)version 3:只 ...
- python函数传参是传值还是传引用?
首先还是应该科普下函数参数传递机制,传值和传引用是什么意思? 函数参数传递机制问题在本质上是调用函数(过程)和被调用函数(过程)在调用发生时进行通信的方法问题.基本的参数传递机制有两种:值传递和引用传 ...
- ubuntu的目录结构
/:根目录,一般根目录下只存放目录,不要存放文件,/etc./bin./dev./lib./sbin应该和根目录放置在一个分区中 /bin:/usr/bin:可执行二进制文件的目录,如常用的命令ls. ...
- syscolumns表中所有字段的意思
--syscolumns表中所有字段的意思 name sysname --列名或过程参数的名称. id int --该列所属的表对象 ID,或与该参数关联的存储过程 ID. xtype tinyint ...
- JavaScript的函数和事件(转)
一.默认函数 JavaScript提供了一些默认的函数 编码函数escape():将非字母.数字字符转换成ASCII码 译码函数unescape():将ASCII码转换成字母.数字字符 求值函数eva ...
- android 项目学习随笔十六( 广告轮播条播放)
广告轮播条播放 if (mHandler == null) {//在此初始化mHandler , 保证消息不重复发送 mHandler = new Handler() { public void ha ...
- javaWeb---Servlet
1.整个Servlet页面跳转访问流程: 1.1:依据form表单的action的值找到web.xml中servlet-mapping的url的值找到对应的java类,在根据form中的method属 ...
- Backup: Array in Perl6
Array in Perl6 继承List,而List又继承Iterable,Positional,Cool ARRAY.pop ARRAY.shift ARRAY.push: VALUES ARRA ...