CSU - 1542

Time Limit: 5000MS   Memory Limit: 262144KB   64bit IO Format: %lld & %llu

Submit Status

Description

Input

Output

Sample Input

6 3
((()))
4
3
1

Sample Output

2
2
1

Hint

题意:先给出一个符合括号匹配的字符串。然后Q次操作

每次操作将某个括号反转,问将哪个括号反转能使字符串的括号再次匹配,位置要取最左端符合条件的。

能够利用前缀和 比方(())那么前缀和分别就是1,2,1,0。观察到。平衡时前缀和都是等于0的。

通过前缀和,我们能够发现规律:

将一个'('翻转成')'会使得从当前位置開始到字符串最后的前缀和都会减2

假设将')'翻转成'(',同理,此位置開始以后的全部前缀和都要加2

而假设减去了2,那怎样添加2抵消掉之前的影响,得到最后的后缀和为零

而减去2的话肯定是'('翻转成')'。那么怎样加一个数抵消掉')'的影响

假设是将p点翻转的话,肯定是从[1,p],找一个')',将')'翻转成'('

有没有发现规律,假设是'('翻转成')',则是在之前的区间将')'翻转成'('。那么将')'翻转成'('时,就是往后,找一个'('将其'('翻转成')'

维护该区间的最小值就可以。仅仅要最小值不小于2,那么该区间的全部值都不会小于2

提供一个朋友的具体解释地址,说的非常好:http://blog.csdn.net/qwb492859377/article/details/47357553

/*
Author: 2486
Memory: 32700 KB Time: 760 MS
Language: C++ Result: Accepted
VJ RunId: 4340427 Real RunId: 149963
*/
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#include <queue> using namespace std;
#define lson rt << 1, l, mid
#define rson rt << 1|1, mid + 1, r
#define root 1, 1, n
const int MAXN = 5e5 + 5;
const int INF = 0x3f3f3f3f; int sum[MAXN << 2];
int Min[MAXN << 2],col[MAXN << 2],val[MAXN << 2];
int S,n,m;
char str[MAXN]; void pushup_1(int rt) {
sum[rt] = min(sum[rt << 1], sum[rt << 1|1]);
} void build(int rt, int l, int r) {
col[rt] = 0;
if(l == r) {
val[rt] = (str[l] == '(' ? 1 : -1);
S += val[rt];
Min[rt] = S;
sum[rt] = val[rt] == 1 ? INF : l;
return;
}
int mid = (l + r) >> 1;
build(lson);
build(rson);
pushup_1(rt);
Min[rt] = min(Min[rt << 1], Min[rt << 1|1]);
} int update_1(int p, int rt, int l, int r) {
if(l == r) {
int tmp = val[rt];
val[rt] *= -1;
sum[rt] = tmp == 1 ? p : INF;
return tmp;
}
int mid = (l + r) >> 1, ret;
if(p <= mid) ret = update_1(p, lson);
if(p > mid) ret = update_1(p, rson);
pushup_1(rt);
return ret;
}
void pushdown(int rt) {
if(col[rt]) {
col[rt << 1] += col[rt];
col[rt << 1|1] += col[rt];
col[rt] = 0;
}
} void pushup_2(int rt) {
Min[rt] = min(Min[rt << 1] + col[rt << 1], Min[rt << 1|1] + col[rt << 1|1]);
} void update_2(int L, int R, int c,int rt, int l, int r) {
if(L <= l && r <= R) {
col[rt] += c;
return;
}
pushdown(rt);
int mid = (l + r) >> 1;
if(L <= mid) update_2(L, R, c, lson);
if(R > mid) update_2(L, R, c, rson);
pushup_2(rt);
} int query(int rt, int l,int r) {
if(Min[rt] + col[rt] >= 2) return l;
if(l == r) return r + 1;
pushdown(rt);
int mid = (l + r) >> 1;
int ret;
if(Min[rt << 1|1] + col[rt << 1|1] >= 2) ret = query(lson);
else ret = query(rson);
pushup_2(rt);
return ret;
} int main() {
int p;
while(~scanf("%d %d",&n,&m)) {
scanf("%s",str+1);
S = 0;
build(root);
while(m--) {
scanf("%d",&p);
int tmp = update_1(p, root);
update_2(p, n, tmp * (-2), root);
printf("%d\n",p = (tmp == 1 ? sum[1] : query(root)));
update_1(p, root);
update_2(p, n, tmp * 2, root);
}
}
return 0;
}

CSU - 1542 Flipping Parentheses (线段树)的更多相关文章

  1. Codeforces Gym 100803G Flipping Parentheses 线段树+二分

    Flipping Parentheses 题目连接: http://codeforces.com/gym/100803/attachments Description A string consist ...

  2. CSUOJ 1542 Flipping Parentheses

    ACM International Collegiate Programming Contest Asia Regional Contest, Tokyo, 2014–10–19 Problem G ...

  3. HDU 1542 Atlantis(线段树扫描线+离散化求面积的并)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  4. CSU 1809 Parenthesis(线段树+前缀和)

    Parenthesis Problem Description: Bobo has a balanced parenthesis sequence P=p1 p2-pn of length n and ...

  5. POJ 1542 Atlantis(线段树 面积 并)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1542 参考网址:http://blog.csdn.net/sunmenggmail/article/d ...

  6. HDU - 1542 扫描线入门+线段树离散化

    扫描线算法+线段树维护简介: 像这种求面积的并集的题目,就适合用扫描线算法解决,具体来说就是这样 类似这种给出点的矩形的对角的点的坐标,然后求出所有矩形面积的交集的问题,可以采用扫描线算法解决.图如下 ...

  7. 【42.49%】【hdu 1542】Atlantis(线段树扫描线简析)

    Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s) ...

  8. HDU - 1542 Atlantis(线段树求面积并)

    https://cn.vjudge.net/problem/HDU-1542 题意 求矩形的面积并 分析 点为浮点数,需要离散化处理. 给定一个矩形的左下角坐标和右上角坐标分别为:(x1,y1).(x ...

  9. CSU 1809 Parenthesis 思维+线段树

    1809: Parenthesis Submit Page     Summary    Time Limit: 5 Sec     Memory Limit: 128 Mb     Submitte ...

随机推荐

  1. Asymptotic I Catalan Number

    卡特兰数出现在许多计数问题中. 常见的例子有:$n$ 个节点的有序二叉树,$2n$ 个括号构成的合法括号序列. 在上面所举的两个例子中,很容易看出卡特兰数满足递推: $$ C_{n+1} = \sum ...

  2. poj 1764 Dice Contest

    题目戳这里. 首先我要吐槽这个题目描述不清.\(2\)对着选手,那选手朝那边?看完别人写的程序后我才知道选手对着目标所在的方向(或左或右). 然后这道题还是不错的,因为他交给我矩阵乘法不只有常规意义下 ...

  3. HDU1285 裸的拓扑排序

    拓扑排序: 拓扑排序是应用于有向无回路图(DAG)上的一种排序方式,对一个有向无回路进行拓扑排序后,所有的顶点形成一个序列,对所有边(u,v),满足u在v的前面.该序列说明了顶点表示的事件或 状态发生 ...

  4. 配置sanmba

    samba是Linux系统上的一种文件共享协议,可以实现Windows系统访问Linux系统上的共享资源,现在介绍一下如何在Ubuntu 14.04上安装和配置samba 工具/原料   Ubuntu ...

  5. bzoj 3744 Gty的妹子序列 区间逆序对数(在线) 分块

    题目链接 题意 给定\(n\)个数,\(q\)个询问,每次询问\([l,r]\)区间内的逆序对数. 强制在线. 思路 参考:http://www.cnblogs.com/candy99/p/65795 ...

  6. 开源免费的C/C++网络库(c/c++ sockets library)(转)

    原文转自 http://blog.csdn.net/weiwangchao_/article/details/8730199 (1)ACE 庞大.复杂,适合大型项目.开源.免费,不依赖第三方库,支持跨 ...

  7. error LNK2001: unresolved external symbol "int g_cTemplates" (?g_cTemplates@@3HA)(转)

    原文转自:http://blog.sina.com.cn/s/blog_639a2ad70101kpen.html 编译directshow若干问题的解决 1.安装好windows sdk,进入dir ...

  8. Java中如何去除List中的重复的值?

    package com.test; import java.util.*; public class Test { /** AAAA AAAA BBBB BBBB CCCC CCCC CCCC CCC ...

  9. python--cProfile,memory_profiler,psutil

    关于测试代码用了多长时间,我们之前介绍了timeit.相较于timeit,python中还有一个更加强大的模块,cProfile模块 (提到cProfile,其实还有一个profile,但profil ...

  10. 【codevs1907】【方格取数3】二分图最大带权独立集

    [pixiv] https://www.pixiv.net/member_illust.php?mode=medium&illust_id=59001242 向大(hei)佬(e)势力学(di ...