题目链接: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. Azure Terraform(五)利用Azure DevOps 实现自动化部署基础资源

    一,引言 上一篇我们结合学习 Azure Traffic Manger 的内容,做了一个负载均衡的基础设施架构.通过 Terraform 部署执行计划,将整个 Azure Traffic Manage ...

  2. 如果数据库上的row格式是mixed或者mixed的格式,如何对比两台数据库服务器上的数据是否一致呢

    如果数据库上的row格式是mixed或者mixed的格式,如何对比两台数据库服务器上的数据是否一致呢

  3. 【Linux】rsh进程缓慢问题处理

    环境CentOS 6.5 由于项目上线时间很长,服务器持续很久没有关机重启过,随后发现rsh反应特别慢 rsh登陆服务器的反应最慢时候3分钟才可以建立链接,登陆之后查看服务器负载是否正常,查看cpu, ...

  4. leetcode 864. 获取所有钥匙的最短路径(BFS,状态压缩)

    题目链接 864. 获取所有钥匙的最短路径 题意 给定起点,要求在最短步骤内收集完所有钥匙,遇到每把锁之前只有 有对应的钥匙才能够打开 思路 BFS+状态压缩典型题目 先确定起点和总的钥匙数目,其次难 ...

  5. cfsetispeed、cfsetospeed和cfsetspeed探究

    在我https://www.cnblogs.com/Suzkfly/p/11055532.html这篇博客中有一个疑问,就是在串口设置波特率的域中,没有将输入输出波特率分开,那为什么会有几个不同的设置 ...

  6. 全栈性能测试修炼宝典-JMeter实战笔记(三)

    JMeter体系结构 简介 JMeter是一款开源桌面应用软件,可用来模拟用户负载来完成性能测试工作. JMeter体系结构 X1~X5是负载模拟的一个过程,使用这些组件来完成负载的模拟 Y1:包含的 ...

  7. Java并发包源码学习系列:阻塞队列实现之PriorityBlockingQueue源码解析

    目录 PriorityBlockingQueue概述 类图结构及重要字段 什么是二叉堆 堆的基本操作 向上调整void up(int u) 向下调整void down(int u) 构造器 扩容方法t ...

  8. 小米开源监控系统Open-Falcon安装使用笔记

    小米开源监控系统Open-Falcon安装使用笔记-BB保你大-51CTO博客 https://blog.51cto.com/chenguomin/1865550

  9. 理解前端模块概念:CommonJs与ES6Module

    前言 现代前端开发每时每刻都和模块打交道.例如,在项目中引入一个插件,或者实现一个供全局使用组件的JS文件.这些都可以称为模块. 在设计程序结构时,不可能把所有代码都放在一起.更为友好的组织方式时按照 ...

  10. dij的优先队列边表优化

    dij的复杂度为v*v,通过优先队列优化后为e*logv. (第一次写,没有过多的测试,不保证对.只当是测试blog了!) #include<cstdio> #include<ios ...