UVA 11402 - Ahoy, Pirates!

题目链接

题意:总的来说意思就是给一个01串,然后有3种操作

1、把一个区间变成1

2、把一个区间变成0

3、把一个区间翻转(0变1,1变0)

思路:线段树搞,开一个延迟标记当前操作就可以,注意几种状态间的转变方式就可以

代码:

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; #define INF 0x3f3f3f3f
#define lson(x) ((x<<1)+1)
#define rson(x) ((x<<1)+2) const int N = 1100005; int t, s[N], n, sn;
char str[55]; struct Node {
int l, r, b, flag;
Node() {}
Node(int l, int r) {
this->l = l; this->r = r;
b = flag = 0;
}
int len() {
return r - l + 1;
}
} node[4 * N]; void pushup(int x) {
node[x].b = node[lson(x)].b + node[rson(x)].b;
} void build(int l, int r, int x = 0) {
node[x] = Node(l, r);
if (l == r) {
node[x].b = s[l];
return;
}
int mid = (node[x].l + node[x].r) / 2;
build(l, mid, lson(x));
build(mid + 1, r, rson(x));
pushup(x);
} void init() {
scanf("%d", &n);
sn = 0;
while (n--) {
int num;
scanf("%d", &num);
scanf("%s", str);
int len = strlen(str);
while (num--) {
for (int i = 0; i < len; i++)
s[sn++] = str[i] - '0';
}
}
build(0, sn - 1);
} //0不变,1黑。2白。3翻转
int getS(int a, int b) {
if (a == 3 && b == 3) return 0;
if (a == 3 && b == 1) return 2;
if (a == 3 && b == 2) return 1;
if (a == 3 && b == 0) return 3;
if (a == 2) return 2;
if (a == 1) return 1;
return 0;
} void pushdown(int x) {
if (node[x].flag) {
int ls = getS(node[x].flag, node[lson(x)].flag);
node[lson(x)].flag = ls;
if (node[x].flag == 2) node[lson(x)].b = 0;
if (node[x].flag == 1) node[lson(x)].b = node[lson(x)].len();
if (node[x].flag == 3) node[lson(x)].b = node[lson(x)].len() - node[lson(x)].b;
int rs = getS(node[x].flag, node[rson(x)].flag);
node[rson(x)].flag = rs;
if (node[x].flag == 2) node[rson(x)].b = 0;
if (node[x].flag == 1) node[rson(x)].b = node[rson(x)].len();
if (node[x].flag == 3) node[rson(x)].b = node[rson(x)].len() - node[rson(x)].b;
node[x].flag = 0;
}
} void set(int l, int r, int v, int x = 0) {
if (node[x].l >= l && node[x].r <= r) {
int ts = getS(v, node[x].flag);
if (v == 1)
node[x].b = node[x].len();
else if (v == 2)
node[x].b = 0;
else
node[x].b = node[x].len() - node[x].b;
node[x].flag = ts;
return;
}
pushdown(x);
int mid = (node[x].l + node[x].r) / 2;
if (l <= mid) set(l, r, v, lson(x));
if (r > mid) set(l, r, v, rson(x));
pushup(x);
} int S(int l, int r, int x = 0) {
if (node[x].l >= l && node[x].r <= r)
return node[x].b;
int mid = (node[x].l + node[x].r) / 2;
int ans = 0;
pushdown(x);
if (l <= mid) ans += S(l, r, lson(x));
if (r > mid) ans += S(l, r, rson(x));
pushup(x);
return ans;
} int main() {
int cas = 0;
scanf("%d", &t);
while (t--) {
init();
int q;
scanf("%d", &q);
char Q[5]; int a, b;
printf("Case %d:\n", ++cas);
int Qcas = 0;
while (q--) {
scanf("%s%d%d", Q, &a, &b);
if (Q[0] == 'F') set(a, b, 1);
if (Q[0] == 'E') set(a, b, 2);
if (Q[0] == 'I') set(a, b, 3);
if (Q[0] == 'S') printf("Q%d: %d\n", ++Qcas, S(a, b));
}
}
return 0;
}

版权声明:本文博主原创文章。博客,未经同意不得转载。

UVA 11402 - Ahoy, Pirates!(段树)的更多相关文章

  1. UVA11402 - Ahoy, Pirates!(线段树)

    UVA11402 - Ahoy, Pirates!(线段树) option=com_onlinejudge&Itemid=8&category=24&page=show_pro ...

  2. 【UVA】11992 - Fast Matrix Operations(段树模板)

    主体段树,要注意,因为有set和add操作,当慵懒的标志下推.递归优先set,后复发add,每次运行set行动add马克清0 WA了好几次是由于计算那一段的时候出问题了,可笑的是我对着模板找了一个多小 ...

  3. BZOJ-3212 Pku3468 A Simple Problem with Integers 裸线段树区间维护查询

    3212: Pku3468 A Simple Problem with Integers Time Limit: 1 Sec Memory Limit: 128 MB Submit: 1278 Sol ...

  4. ZOJ 1610 间隔染色段树

    要长8000仪表板.间染色的范围,问:最后,能看到的颜色,而且颜色一共有段出现 覆盖段 数据对比水   水可太暴力 段树: #include "stdio.h" #include ...

  5. HDU 1394 Minimum Inversion Number (数据结构-段树)

    Minimum Inversion Number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java ...

  6. PKU A Simple Problem with Integers (段树更新间隔总和)

    意甲冠军:一个典型的段树C,Q问题,有n的数量a[i] (1~n),C, a, b,c在[a,b]加c Q a b 求[a,b]的和. #include<cstdio> #include& ...

  7. BZOJ 2588 Count on a tree (COT) 是持久的段树

    标题效果:两棵树之间的首次查询k大点的权利. 思维:树木覆盖树,事实上,它是正常的树木覆盖了持久段树. 由于使用权值段树可以寻求区间k大,然后应用到持久段树思想,间隔可以做减法.详见代码. CODE: ...

  8. lintcode-439-线段树的构造 II

    439-线段树的构造 II 线段树是一棵二叉树,他的每个节点包含了两个额外的属性start和end用于表示该节点所代表的区间.start和end都是整数,并按照如下的方式赋值: 根节点的 start ...

  9. lintocde-247-线段树的查询 II

    247-线段树的查询 II 对于一个数组,我们可以对其建立一棵 线段树, 每个结点存储一个额外的值 count 来代表这个结点所指代的数组区间内的元素个数. (数组中并不一定每个位置上都有元素) 实现 ...

随机推荐

  1. hdu1428之spfa+dfs

    漫步校园 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submi ...

  2. Do you master on array in C ?

    Do you master on array in C ? 因为新标准C99的支持变长数组, 差点儿C的标准特性就是看着gcc来的(Linux 内核严重依赖GCC) int mani() { cons ...

  3. fastdfs storage server的设计与实现

     fastdfs是一个针对互联网应用设计的分布式文件系统.具有架构简单.结构清晰.代码量小等特点. 详细的介绍及架构请參考分布式文件系统FastDFS架构剖析(http://www.program ...

  4. hdu2151(递推dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2151 分析: DP.思路:全盘扫描.     i表示时间,l表示第几棵树,方程:     step[i ...

  5. 番外:android模拟器连不上网

    1.删除你PC端得备用DNS,只留一个即可.确保能够上网. 注意:这个虽然不是必须的,出错点也不一定在他,但是我建议这样做,因为我们不确定到底模拟器和我们的PC是否使用的是一个DNS,不是的话,就会造 ...

  6. awk使用的实例

    1.使用split函数 name.url的内容: 上海    http://trip.elong.com/shanghai/jingdian elong   destination 云南    htt ...

  7. 本科非cs菜鸟计算机面试实录

    两年制小硕,本硕期间差不多都打酱油的.本科非cs专业,硕士cs,编程基础一般,专业基础尚可.研究生期间分析分析了pgsql数据库的源码:同时实验室一些杂项目:自己业余为了应试读了些计算机书.自己当时q ...

  8. pygame写的弹力球

    这是pygame写的弹力球 运行效果: ======================================================== 代码部分: ================= ...

  9. UVa 103 - Stacking Boxes (LIS,打印路径)

    链接:UVa 103 题意:给n维图形,它们的边长是{d1,d2,d3...dn},  对于两个n维图形,求满足当中一个的全部边长 依照随意顺序都一一相应小于还有一个的边长,这种最长序列的个数,而且打 ...

  10. C 一个字符串有三段,第一段原样输出,第二段为要输出字符串的长度,第三段为依据第二段长度补齐第一段

    C 一个字符串有三段,第一段原样输出.第二段为要输出字符串的长度,第三段为依据第二段长度补齐第一段 比如:输入abc 11 12.输出abc12121212 #include<stdio.h&g ...