题目

题解

直接套黄学长模板。

Orz

代码

#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000000
#define n (65536 * 2 + 1)
char ch[5];
int read() {
int x = 0, f = 0;
char ch = getchar();
while (ch < '0' || ch > '9') {
if (ch == '(')
f = -1;
ch = getchar();
}
while (ch >= '0' && ch <= '9') {
x = x * 10 + ch - '0';
ch = getchar();
}
if (ch == ')')
f = 1;
return x * 2 - f;
}
struct seg {
int l, r, val, tag, rev;
} t[4 * n]; void build(int k, int l, int r) {
t[k].l = l;
t[k].r = r;
t[k].tag = -1;
if (l == r)
return;
int mid = (l + r) >> 1;
build(k << 1, l, mid);
build(k << 1 | 1, mid + 1, r);
} void pushdown(int k) {
int tag = t[k].tag, rev = t[k].rev;
t[k].tag = -1;
t[k].rev = 0;
if (t[k].l == t[k].r) {
if (tag != -1)
t[k].val = tag;
t[k].val ^= rev;
return;
}
if (tag != -1) {
t[k << 1].tag = t[k << 1 | 1].tag = tag;
t[k << 1].rev = t[k << 1 | 1].rev = 0;
}
t[k << 1].rev ^= rev;
t[k << 1 | 1].rev ^= rev;
}
int query(int k, int x) {
pushdown(k);
int l = t[k].l, r = t[k].r;
if (l == r)
return t[k].val;
int mid = (l + r) >> 1;
if (x <= mid)
return query(k << 1, x);
else
return query(k << 1 | 1, x);
}
void modify(int k, int x, int y, int val) {
if (y < x)
return;
pushdown(k);
int l = t[k].l, r = t[k].r;
if (l == x && r == y) {
if (val == -1)
t[k].rev ^= 1;
else
t[k].tag = val;
return;
}
int mid = (l + r) >> 1;
if (y <= mid)
modify(k << 1, x, y, val);
else if (x > mid)
modify(k << 1 | 1, x, y, val);
else {
modify(k << 1, x, mid, val);
modify(k << 1 | 1, mid + 1, y, val);
}
}
void rever(int k, int x, int y) { modify(k, x, y, -1); }
int main() {
build(1, 1, n);
while (scanf("%s", ch) != EOF) {
int a = read(), b = read();
a += 2;
b += 2;
switch (ch[0]) {
case 'U':
modify(1, a, b, 1);
break;
case 'I':
modify(1, 1, a - 1, 0);
modify(1, b + 1, n, 0);
break;
case 'D':
modify(1, a, b, 0);
break;
case 'C':
modify(1, 1, a - 1, 0);
modify(1, b + 1, n, 0);
rever(1, a, b);
break;
case 'S':
rever(1, a, b);
break;
}
}
int start = -1, last = -1, flag = 0;
for (int i = 1; i <= n; i++) {
if (query(1, i)) {
if (start == -1)
start = i;
last = i;
} else {
if (start != -1) {
if (flag)
printf(" ");
else
flag = 1;
if (start & 1)
printf("(");
else
printf("[");
printf("%d", start / 2 - 1);
printf(",");
printf("%d", (last + 1) / 2 - 1);
if (last & 1)
printf(")");
else
printf("]");
}
last = start = -1;
}
}
if (!flag)
printf("empty set");
return 0;
}

[bzoj3226][Sdoi2008]校门外的区间——线段树的更多相关文章

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

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

  2. 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 : ...

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

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

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

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

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

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

  6. BZOJ-3226 校门外的区间 线段数+拆点(类似的思想)

    shabi题....bzoj关键字检查freopen??可怕,,1A的卡了一小时.... 3226: [Sdoi2008]校门外的区间 Time Limit: 10 Sec Memory Limit: ...

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

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

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

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

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

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

随机推荐

  1. cf#513 B. Maximum Sum of Digits

    B. Maximum Sum of Digits time limit per test 2 seconds memory limit per test 512 megabytes input sta ...

  2. C++学习009预处理器指令符号 # ## #@ 符号的使用

    # ## #@ 符号是预处理器指令符号. 当预处理器遇到#指令符号时,会将#之后的部分用双引号括起来 当预处理去遇到##指令符号时,直接将##前后部分连接起来 当预处理器遇到#@指令符号,将#@之后的 ...

  3. Selenium 启动无头浏览器,只有chrome 和 firefox的,没有IE

    使用无头浏览器,可以避免掉不确定的弹出框对脚本稳定性的影响,还能在脚本执行过程中省略掉了css 加载的时间. 以下是Selenium 启动无头浏览器的方法,只有chrome 和 firefox的. p ...

  4. 【leetcode】19. 删除链表的倒数第N个节点

    描述 给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点. 示例 给定一个链表: 1->2->3->4->5, 和 n = 2. 当删除了倒数第二个节点后,链表变 ...

  5. [org.hibernate.engine.jdbc.spi.SqlExceptionHelper]SQL Error: 1064, SQLState: 42000问题的解决办法

    [org.hibernate.engine.jdbc.spi.SqlExceptionHelper]SQL Error: 1064, SQLState: 42000问题的解决办法. 出现这种情况的原因 ...

  6. Mac下安装OpenCV问题

    最近看了纹理特征方面的paper,看了一些资料之后,想要实际动手实现一下其中LBP算法,果然OpenCV中已经实现. 问题 No module named "cv2" 当我在我们项 ...

  7. Mac OSX 10.11安装Jekyll

    一说常见的博客管理工具大家想到的就是WordPress.不过现在部分个人博客用户开始从WordPress转移到Jekyll上了.Jekyll是一种本地生成静态页面进而线上发布的博客工具,而且现在已经有 ...

  8. kali linux下的常用bash命令

    虚拟机版本默认用户root 密码toor ls:显示当前目录包含的文件及文件夹 ls -l:以常规格式显示当前目录包含的文件及文件夹(开头字母解释:d:目录 -:文件 c:设备文件 l:链接 b:块设 ...

  9. [NOI2017]游戏 2-sat

    ---题面--- 题解: 首先观察到,如果没有x的话,这就是一个2-sat问题. 建图方式:对于限制d1 c1 d2 c2,其中d1, d2分别代表比赛编号,c1, c2代表出场的赛车. 1,如果d1 ...

  10. 用原生JavaScript做个简单的回到顶部

    很多网页在下方都会放置一个“返回顶部”按钮,尤其是页面底部没有导航的网页,这样可以帮助访客重新找到导航或者重温一遍广告(想得真美).随着近几年来 JavaScript 的应用日渐广泛,滑动效果无处不在 ...