题目链接:http://codeforces.com/gym/100803/attachments/download/3816/20142015-acmicpc-asia-tokyo-regional-contest-en.pdf

题意:给你一些匹配好的括号,长为n,有m个操作,每次操作把其中一个"("改为")",或者把其中一个")"改为"(",问你改动一个单括号,使得改后的括号序列任然完美匹配,如果有多种该法,求出最前面的。

思路:可以分两种情况分类讨论,先求出所有下标的前缀和,如果是第一种情况,那么只要从左到右找到第一个")"就行了,可以用set维护,如果是第二种情况,那么可以用线段树维护区间的最小值,然后用二分查找出最前面的一个大于等于2,且后面的前缀和的值都大于等于2的下标。

#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<stack>
#include<string>
#include<algorithm>
using namespace std;
typedef long long ll;
#define maxn 300030
char s[maxn];
int sum[maxn];
#define inf 888888888
struct node{
int l,r,minx,add;
}b[4*maxn]; set<int>myset;
set<int>::iterator it; void build(int l,int r,int i)
{
int mid;
b[i].l=l;b[i].r=r;b[i].add=0;
if(l==r){
b[i].minx=sum[l];
return;
}
mid=(l+r)/2;
build(l,mid,i*2);
build(mid+1,r,i*2+1);
b[i].minx=min(b[i*2].minx,b[i*2+1].minx);
} void update(int l,int r,int add,int i)
{
int mid;
if(b[i].l==l && b[i].r==r){
b[i].add+=add;
b[i].minx+=add;
return;
}
if(b[i].add){
b[i*2].add+=b[i].add;
b[i*2].minx+=b[i].add;
b[i*2+1].add+=b[i].add;
b[i*2+1].minx+=b[i].add;
b[i].add=0;
}
mid=(b[i].l+b[i].r)/2;
if(r<=mid)update(l,r,add,i*2);
else if(l>mid)update(l,r,add,i*2+1);
else {
update(l,mid,add,i*2);
update(mid+1,r,add,i*2+1); }
b[i].minx=min(b[i*2].minx,b[i*2+1].minx); } int question(int l,int r,int i)
{
int mid;
if(b[i].l==l && b[i].r==r){
return b[i].minx;
}
if(b[i].add){
b[i*2].add+=b[i].add;
b[i*2].minx+=b[i].add;
b[i*2+1].add+=b[i].add;
b[i*2+1].minx+=b[i].add;
b[i].add=0;
}
mid=(b[i].l+b[i].r)/2;
if(r<=mid)return question(l,r,i*2);
else if(l>mid)return question(l,r,i*2+1);
else {
return min(question(l,mid,i*2),question(mid+1,r,i*2+1) ); }
b[i].minx=min(b[i*2].minx,b[i*2+1].minx); } int main()
{
int n,m,i,j,c,l,r,mid;
while(scanf("%d%d",&n,&m)!=EOF)
{
scanf("%s",s+1);
sum[0]=0;
myset.clear();
for(i=1;i<=n;i++){
if(s[i]=='('){
sum[i]=sum[i-1]+1;
}
else{
sum[i]=sum[i-1]-1;
myset.insert(i);
}
}
build(1,n,1);
for(i=1;i<=m;i++){
scanf("%d",&c);
if(s[c]=='('){
s[c]=')';
myset.insert(c);
update(c,n,-2,1);
it=myset.begin();
cout<<*it<<endl;
myset.erase(it);
update(*it,n,2,1);
s[*it]='(';
}
else if(s[c]==')'){
s[c]='(';
myset.erase(c);
update(c,n,2,1);
l=1;r=n;
while(l<=r){
mid=(l+r)/2;
if(question(mid,n,1)>=2)r=mid-1;
else l=mid+1;
}
printf("%d\n",l);
s[l]=')';
update(l,n,-2,1);
myset.insert(l);
}
}
}
return 0;
}

Gym 100803G Flipping Parentheses的更多相关文章

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

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

  2. CSU - 1542 Flipping Parentheses (线段树)

    CSU - 1542 Flipping Parentheses Time Limit: 5000MS   Memory Limit: 262144KB   64bit IO Format: %lld ...

  3. CSUOJ 1542 Flipping Parentheses

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

  4. Flipping Parentheses~Gym 100803G

    Description A string consisting only of parentheses '(' and ')' is called balanced if it is one of t ...

  5. Gym 101606F - Flipping Coins - [概率DP]

    题目链接:https://codeforc.es/gym/101606/problem/F 题解: 假设 $f[i][j]$ 表示抛 $i$ 次硬币,有 $j$ 个硬币正面朝上的概率. 所以只有两种挑 ...

  6. Flipping Parentheses(CSU1542 线段树)

    http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1542 赛后发现这套题是2014东京区域赛的题目,看了排名才发现自己有多low  = =! 题目大意 ...

  7. 2014-2015 ACM-ICPC, Asia Tokyo Regional Contest

    2014-2015 ACM-ICPC, Asia Tokyo Regional Contest A B C D E F G H I J K O O O O   O O         A - Bit ...

  8. Codeforces Gym 100610 Problem A. Alien Communication Masterclass 构造

    Problem A. Alien Communication Masterclass Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codefo ...

  9. Gym 101606 - A/B/C/D/E/F/G/H/I/J/K/L - (Undone)

    链接:https://codeforces.com/gym/101606 A - Alien Sunset 暴力枚举小时即可. #include<bits/stdc++.h> using ...

随机推荐

  1. maven 报的一堆错

    今天初学maven,刚开始下载的是Apache-maven-3.6.2然后配置运行一个servlet,但是在pom.xml中写jar包坐标时一直报错显示红色,本地仓库和官网上的中央仓库都试过了就是依赖 ...

  2. TCP/IP五层模型-应用层-DNS协议

    ​1.定义:域名解析协议,把域名解析成对应的IP地址. 2.分类:①迭代解析:DNS所在服务器若没有可以响应的结果,会向客户机提供其他能够解析查询请求的DNS服务器地址,当客户机发送查询请求时,DNS ...

  3. Java 反射修改类的常量值、静态变量值、属性值

    前言 有的时候,我们需要修改一个变量的值,但变量也许存在于 Jar 包中或其他位置,导致我们不能从代码层面进行修改,于是我们就用到了下面的场景,通过反射来进行修改变量的值. 定义一个实体类 class ...

  4. MySQL sql命令行操作数据库

    数据库命令行操作 命令行操作数据库, [if exists] 可加可不加, 命令行操作一定要加英文分号 ; 结尾 创建数据库 : create database [if not exists] 数据库 ...

  5. service自动发现,yaml文件管理内外部端口访问

    service服务发现 [root@k8s-master ~]# vim busybox-5d4f595646-dzjv4.yaml apiVersion: v1 kind: Pod metadata ...

  6. springAOP的概述及使用

    Spring AOP SpringAOP是Spring中非常重要的功能模块之一,该模块提供了面向切面编程,在事务处理,日志记录,安全控制等操作中广泛使用. SpringAOP的基本概念 AOP的概念 ...

  7. QT串口助手(三):数据接收

    作者:zzssdd2 E-mail:zzssdd2@foxmail.com 一.前言 开发环境:Qt5.12.10 + MinGW 实现的功能 串口数据的接收 ascii字符形式显示与hex字符形式显 ...

  8. echarts图表X轴文字过长解决解决方案:根据文字长度自动旋转

    Echarts 标签中文本内容太长的时候怎么办 ? 关于这个问题搜索一下,有很多解决方案.无非就是 省略(间隔显示).旋转文字方向.竖排展示 前面两种解决方案,就是echarts暴露的: {   ax ...

  9. 一文打尽 Linux/Windows端口复用实战

    出品|MS08067实验室(www.ms08067.com) 本文作者:Spark(Ms08067内网安全小组成员) 定义:端口复用是指不同的应用程序使用相同端口进行通讯. 场景:内网渗透中,搭建隧道 ...

  10. based on Greenlets (via Eventlet and Gevent) fork 孙子worker 比较 gevent不是异步 协程原理 占位符 placeholder (Future, Promise, Deferred) 循环引擎 greenlet 没有显式调度的微线程,换言之 协程

    gevent GitHub - gevent/gevent: Coroutine-based concurrency library for Python https://github.com/gev ...