Codeforces Round #350 (Div. 2) E 思维模拟
给出一个合法的括号串 有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 思维模拟的更多相关文章
- Codeforces Round #350 (Div. 2) E. Correct Bracket Sequence Editor 模拟
题目链接: http://codeforces.com/contest/670/problem/E 题解: 用STL的list和stack模拟的,没想到跑的还挺快. 代码: #include<i ...
- Codeforces Round #350 (Div. 2) D2. Magic Powder - 2
题目链接: http://codeforces.com/contest/670/problem/D2 题解: 二分答案. #include<iostream> #include<cs ...
- Codeforces Round #350 (Div. 2) E. Correct Bracket Sequence Editor (链表)
题目链接:http://codeforces.com/contest/670/problem/E 给你n长度的括号字符,m个操作,光标初始位置是p,'D'操作表示删除当前光标所在的字符对应的括号字符以 ...
- Codeforces Round #350 (Div. 2)解题报告
codeforces 670A. Holidays 题目链接: http://codeforces.com/contest/670/problem/A 题意: A. Holidays On the p ...
- Codeforces Round #350 (Div. 2) E. Correct Bracket Sequence Editor 栈 链表
E. Correct Bracket Sequence Editor 题目连接: http://www.codeforces.com/contest/670/problem/E Description ...
- Codeforces Round #350 (Div. 2) D1. Magic Powder - 1 二分
D1. Magic Powder - 1 题目连接: http://www.codeforces.com/contest/670/problem/D1 Description This problem ...
- Codeforces Round #350 (Div. 2) C. Cinema 水题
C. Cinema 题目连接: http://www.codeforces.com/contest/670/problem/C Description Moscow is hosting a majo ...
- 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 ...
- Codeforces Round #350 (Div. 2) A. Holidays 水题
A. Holidays 题目连接: http://www.codeforces.com/contest/670/problem/A Description On the planet Mars a y ...
随机推荐
- Experimental Educational Round: VolBIT Formulas Blitz
cf的一次数学场... 递推 C 题意:长度<=n的数只含有7或8的个数 分析:每一位都有2种可能,累加不同长度的方案数就是总方案数 组合 G 题意:将5个苹果和3个梨放进n个不同的盒子里的方案 ...
- BestCoder Round #71 (div.2)
数学 1001 KK's Steel 类似斐波那契求和 #include <cstdio> #include <cstring> #include <algorithm& ...
- Floyd_Warshall POJ 3660 Cow Contest
题目传送门 题意: m组关系,A能打败B,问最后有几头牛的排名能确定 分析:如果排名确定,那么能打败它的到它一定通,它到能打败的一定能通,也就是和为n-1.用Floyd的传递闭包 #include & ...
- 【Cocos2d-x游戏开发】浅谈游戏中的坐标系
无论是开发2D还是开发3D游戏,首先必须弄清楚坐标系的概念.在Cocos2d-x中,需要了解的有OpenGL坐标系.世界坐标系和节点坐标系. 1.UI坐标系 IOS/Android/Windows ...
- js 四舍五入保留二位小数
1. 最笨的办法....... [我就怎么干的.........] function get() { var s = 22.127456 + ""; var str = s.sub ...
- javascript的基本语法、数据结构
本篇学习资料主要讲解javascript的基本语法.数据结构 无论是传统的编程语言,还是脚本语言,都具有数据类型.常量和变量.运算符.表达式.注释语句.流程控制语句等基本元素构成,这些基本元 ...
- 如何用ActiveQt写导出类
如何用ActiveQt写导出类 最近一直在用ActiveQt框架来写ActiveX插件, 由于项目需要提示类的导出, 所以上午捣鼓了一下, 现在记录记录.其实内容主要是把Qt手册里自己用到的部分整理一 ...
- PHP递归小例子
$news = M('productbase'); function digui($idd){ $child=M('navclass')->where('f_id='.$idd)->sel ...
- Java_关于App class loader的总结
Java本身是一种设计的非常简单,非常精巧的语言,所以Java背后的原理也很简单,归结起来就是两点: 1.JVM的内存管理 理解了这一点,所有和对象相关的问题统统都能解决 2.JVM Class Lo ...
- 人工智能 --test
http://zhidao.baidu.com/link?url=9qp_SbSRfzMezkD25FZiWyNDsMxgcK6lecYYt0SW1ESsqkRaV5LYQ-0ysk3F2e35ajA ...