给出一个合法的括号串 有LRD三种操作 LR分别是左右移动当前位置 且合法

D为删除这个括号和里面的所有 当删除完成后 位置向右移动 如果不能移动 就向左

比赛都是很久远的事情了 写这道题也是一时兴起 先写了一发暴力 先拿a记录下来与这个括号相匹配的括号位置 拿vis记录括号是否被删除 每次碰到false的括号就整体跳过

然后一气跑到了test78才停下来 想了想暴力肯定不行 就加了l数组和r数组 来记录当前位置的左右仍存在的括号在哪 每次进行移动和删除的时候都利用这个进行移动 顺便更改 有一种并查集路径压缩的感觉

然后一气跑到了test93接着超时 看了一眼数据 这时候长度已经满了 基本是()()()这样 但是我的路径压缩应该不怕这个的 比较不解

过了两天又看了一眼代码 发现我的lr数组可以做到LR是线性的 但是D的时候 我先向右寻找 如果找不到的话 再向左寻找 这个时候 由于我设定的是 如果可以找到一个true的点 就进行更改 这样可能会有很多时间被浪费在无用的D后向右探测

于是改了一下 如果D后向右没有找到可行的括号 就直接将r[w]设为n+1 直接不可行

这里和并查集不同的是 并查集的路径压缩 这条路径中的所有的fa[x]最终都会是一个顶点 而这个题目中 所有变为false的括号都不会再出现了 它必定会被我以某种方式跳过去(通过匹配括号的转移和lr数组的优化) 所以我只需要更改仍然true的点的lr就可以了

当然..做过了这道题之后去百度了一下别人的解法..看到别人题解上的链表两字 突然就明白怎么做了..

当然其实路径压缩后 实际每次LRD的操作还是O(1)的

#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<math.h>
#include<map>
#include<queue>
#include<iostream>
#include<vector>
#include<string>
#include<set>
#include<stack>
using namespace std;
bool vis[500050];
int n,m,p;
char s[500050];
int a[500050];
char z[500050];
stack<int >sta;
int l[500050];
int r[500050];
int w;
int main()
{
cin>>n>>m>>p;
scanf("%s",s+1);
scanf("%s",z+1);
while(!sta.empty())
sta.pop();
for(int i=1;i<=n;i++)
{
if(s[i]=='(')
{
sta.push(i);
}
else
{
a[i]=sta.top();
sta.pop();
}
}
memset(vis,true,sizeof(vis));
for(int i=n;i>=1;i--)
{
if(s[i]==')')
{
int x=a[i];
a[x]=i;
}
}
for(int i=1;i<=n;i++)
{
l[i]=i-1;
r[i]=i+1;
} w= p;
for(int i=1;i<=m;i++)
{
if(z[i]=='L')
{
int ww=w;
w=l[w];
while(w>=1&&vis[w]==false)
{
if(s[w]==')')
{
int x=a[w];
w=x;
w=l[w];
}
else
{
w=l[w];
}
}
l[ww]=w;
r[w]=ww;
}
else if(z[i]=='R')
{
int ww=w;
w=r[w];
while(w<=n&&vis[w]==false)
{
if(s[w]=='(')
{
int x= a[w];
w=x;
w=r[w];
}
else
{
w=r[w];
}
}
r[ww]=w;
l[w]=ww;
}
else if(z[i]=='D')
{
int x=a[w];
vis[x]=false;
vis[w]=false;
int cs= w;
if(s[w]=='(')
{
int x=a[w];
w=x;
}
int ww=w;
w=r[w];
while(w<=n&&vis[w]==false)
{
if(s[w]=='(')
{
int x= a[w];
w=x;
w=r[w];
}
else if(s[w]==')')
{
w=r[w];
}
}
if(w<=n)
{
r[cs]=w;
r[ww]=w;
l[w]=ww;
continue;
}
r[cs]=n+1;
r[ww]=n+1;
w=cs;
if(s[w]==')')
{
int x=a[w];
w=x;
}
ww=w;
w=l[w];
while(w>=1&&vis[w]==false)
{
if(s[w]==')')
{
int x=a[w];
w=x;
w=l[w];
}
else if(s[w]=='(')
{
w=l[w];
}
}
l[ww]=w;
l[cs]=w;
r[w]=ww;
}
}
for(int i=1;i<=n;i++)
{
if(!vis[i])
{
for(int k=i;k<=a[i];k++)
vis[k]=false;
i=a[i];
}
}
for(int i=1;i<=n;i++)
if(vis[i])
printf("%c",s[i]);
printf("\n");
}

  

Codeforces Round #350 (Div. 2) E 思维模拟的更多相关文章

  1. Codeforces Round #350 (Div. 2) E. Correct Bracket Sequence Editor 模拟

    题目链接: http://codeforces.com/contest/670/problem/E 题解: 用STL的list和stack模拟的,没想到跑的还挺快. 代码: #include<i ...

  2. Codeforces Round #350 (Div. 2) D2. Magic Powder - 2

    题目链接: http://codeforces.com/contest/670/problem/D2 题解: 二分答案. #include<iostream> #include<cs ...

  3. Codeforces Round #350 (Div. 2) E. Correct Bracket Sequence Editor (链表)

    题目链接:http://codeforces.com/contest/670/problem/E 给你n长度的括号字符,m个操作,光标初始位置是p,'D'操作表示删除当前光标所在的字符对应的括号字符以 ...

  4. Codeforces Round #350 (Div. 2)解题报告

    codeforces 670A. Holidays 题目链接: http://codeforces.com/contest/670/problem/A 题意: A. Holidays On the p ...

  5. Codeforces Round #350 (Div. 2) E. Correct Bracket Sequence Editor 栈 链表

    E. Correct Bracket Sequence Editor 题目连接: http://www.codeforces.com/contest/670/problem/E Description ...

  6. Codeforces Round #350 (Div. 2) D1. Magic Powder - 1 二分

    D1. Magic Powder - 1 题目连接: http://www.codeforces.com/contest/670/problem/D1 Description This problem ...

  7. Codeforces Round #350 (Div. 2) C. Cinema 水题

    C. Cinema 题目连接: http://www.codeforces.com/contest/670/problem/C Description Moscow is hosting a majo ...

  8. Codeforces Round #350 (Div. 2) B. Game of Robots 水题

    B. Game of Robots 题目连接: http://www.codeforces.com/contest/670/problem/B Description In late autumn e ...

  9. Codeforces Round #350 (Div. 2) A. Holidays 水题

    A. Holidays 题目连接: http://www.codeforces.com/contest/670/problem/A Description On the planet Mars a y ...

随机推荐

  1. 浩瀚技术 安卓版移动开单手持微POS PDA无线移动开单软件 -安卓版移动手持开单设备

    PDA数据采集器,是深圳浩瀚技术有限公司最新研发的一款安卓版移动手持开单设备,它通过WIFI和GPRS连接并访问电脑,从进销存软件中读取数据,实现移动开单,打破电脑开单模式. 它自带扫描器,可直接扫描 ...

  2. VS2013单元测试及代码覆盖率分析--Xunit

    1,Javaweb中有jmeter.jacoco.ant.badboy等集成测试代码覆盖率的方式,C#代码的覆盖率怎么测试呢?VS2013的IDE上本身并未集成测试的工具,以下讲解VS2013中C#代 ...

  3. zookeeper + LevelDB + ActiveMQ实现消息队列高可用

    通过集群实现消息队列高可用. 消息队列在项目中存储订单.邮件通知.数据分发等重要信息,故对消息队列稳定可用性有高要求. 现在通过zookeeper选取activemq leader的形式实现当某个ac ...

  4. PHP 自带查询运行内存的函数

    memory_get_usage - 返回分配给 PHP 的内存量 int memory_get_usage ([ bool $real_usage = false ] ) 返回当前分配给你的 PHP ...

  5. ccpc_南阳 C The Battle of chibi dp + 树状数组

    题意:给你一个n个数的序列,要求从中找出含m个数的严格递增子序列,求能找出多少种不同的方案 dp[i][j]表示以第i个数结尾,形成的严格递增子序列长度为j的方案数 那么最终的答案应该就是sigma( ...

  6. MVC 异常处理机制

    方法一 :web.config配置文件的 system.web 接点下添加,若为On则不会将异常信息反馈到用户,而是友好的跳转到error.htm <customErrors mode=&quo ...

  7. Visual Studio 设置 Inherited include Directories

    在用Visual Studio进行开发的时候,避免不了要使用一些常用的第三方提供的库.如果是一次两次设置还能让人忍受,但是如果要写很多项目的话,设置这些库真的很让人头疼.不过Visual Studio ...

  8. HDU 2852 (树状数组+无序第K小)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2852 题目大意:操作①:往盒子里放一个数.操作②:从盒子里扔掉一个数.操作③:查询盒子里大于a的第K小 ...

  9. 转:苹果应用商店DNS修改加快下载速度

    苹果应用商店DNS修改加快下载速度 具体方法:依次点击进入[设置]→[无线局域网]→[WiFi网络右侧小i图标]→更改DNS地址,可以按照自身需求选择以下某个DNS进行更换. OpenDNS:208. ...

  10. React.js 常用技术要点

    最近在公司的一个移动端WEB产品中使用了React这个框架(并不是React-Native),记录一下在开发过程中遇到的各种问题以及对应的解决方法,希望能对读者有所帮助. React原则 React不 ...