jzyzoj 栈——P1148:括号匹配加强版
括号匹配加强版
描述 Description
对于一个由(,),[,]括号组成的字符串,求出其中最长的括号匹配字串。 具体来说,满足如下条件的字符串成为括号匹配的字符串: (1) (),[] 是括号匹配的字符串。 (2) 若A是括号匹配的串,则(A)或[A] 是括号匹配的字符串。 (3) 若A和B都是括号匹配的字符串,则A+B也是括号匹配的字符串。(这里的+是字符串的加法运算)。 例如:(),[],([]),()() 都是括号匹配的字符串,而][,[( ]),(]则不是。 字符串A的子串是指由A中连续若干个字符组成的字符串。例如:A,B,C,ABC,CAB,ABCCABC都是ABCABC的子串。空串是任何字符串的子串。
输入格式 Input Format
输入一行,为一个仅由()[]组成的非空字符串。(括号都是英文输入法的括号)
输出格式 Output Format
输出也仅有一行,为最长的括号匹配子串。若有相同长度的子串,输出位置靠前的子串。
样例输入 Sample Input
【输入样例1】 ([(][()]]()
【输入样例2】 ())[]
样例输出 Sample Output
【输出样例2】 [()]
【输出样例2】 ()
时间限制 Time Limitation 1s
注释 Hint 【数据规模】 对于20%的数据,字符串长度<=100 对于50%的数据,字符串长度<=10,000 对于100%的数据,字符串长度<=1,000,000
思路:这道题栈的经典应用,需要注意的就是如果不匹配栈需要清空。对于题上给的 A匹配,B匹配,则A+B匹配 我们可以把每个匹配的bool标记,这样最后枚举的时候 for i=1.....n bool[i]=1 肯定是连续的。
代码:
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<iostream>
using namespace std;
int stack[];
int top=;
//char ans[1000100];
char c[];
bool f[];
int n=;
//int len=0;
//int id=0;
//int t=0;
inline void push(int x)
{
stack[++top]=x;
} void check(int i)
{
//cout<<stack[top]<<' ';
if(top>)
{
if(c[stack[top]]=='(')
{
if(c[i]==']') top=;
else if(c[i]=='('||c[i]=='[') push(i);
else if(c[i]==')')
{
f[stack[top]]=;
f[i]=;
--top;
}
}
else if(c[stack[top]]=='[')
{
if(c[i]==')') top=;
else if(c[i]=='('||c[i]=='[') push(i);
else if(c[i]==']')
{
f[i]=;
f[stack[top]]=;
--top;
}
}
else if((c[stack[top]]==')')||(c[stack[top]]==']'))
{
top=;
push(i);
}
}
else
{
//cout<<"ccccc:"<<i<<' ';
if((c[i]!=']')||(c[i]!=')'))
{
push(i);
}
else return;
}
//cout<<stack[top]<<' ';
} void work()
{
int id;
int len=;
int ans=;
//for(int i=1;i<=n;i++) cout<<f[i]<<' ';cout<<endl;
for(int i=;i<=n;++i)
{
//cout<<f[i]<<' ';
if(f[i])
{
++len;
int t=i+;
while(f[t])
{
++len;
++t;
}
i=t-;
if(len>ans)
{
ans=len;
id=i-len+;
}
len=;
}
}
//cout<<"id:"<<id<<endl;
//cout<<"ans:"<<ans<<endl;
for(int i=id;i<=id+ans-;++i)
{
printf("%c",c[i]);
}
} int main()
{
//freopen("a.txt","r",stdin);
//freopen("b.txt","w",stdout);
memset(f,,sizeof(f));
char ch;
ch=getchar();
while(ch>=)
{
c[++n]=ch;
//cout<<c[n]<<' ';
ch=getchar();
}
//cout<<endl;
//cout<<"n:"<<n<<endl;
for(int i=;i<=n;++i)
{
check(i);
}
//cout<<endl;
work();
return ;
}
jzyzoj 栈——P1148:括号匹配加强版的更多相关文章
- STL-stack和顺序栈实现括号匹配
2018-11-11-14:28:31 1.顺序栈 下面是我用数组实现的顺序栈,包含的函数有出入栈,查看栈顶元素,栈的大小,栈是否空等函数,当栈空间不够用时,对应的数组会自动增长. /******** ...
- HDU 4283 You Are the One ★(进出栈的括号匹配性质:区间DP)
题意 有一个队列,每个人有一个愤怒值D,如果他是第K个上场,不开心指数就为(K-1)*D.但是边上有一个小黑屋(一个FILO堆栈),可以一定程度上调整上场程序,求一种安排上场方案使得所有人的不开心指数 ...
- OJP1147括号匹配加强版(栈)与P1153乱头发节(单调栈)
惨兮兮的被刷掉2%的通过率后在经过思考和dalao的指点后终于A掉了这道题 强烈建议修改这题的样例,实在太迷惑人,各种错误算法都能过 比如说这是一份错误代码,看懂了也不要学思路,和正解不知道差到哪里去 ...
- C语言数据结构之栈:括号匹配
括号匹配这是个很简单的题目,如果只有小括号,就模拟进栈和出栈的过程就行了: 注:输入时'@'作为结束标志 #include <stdio.h> int main() { freopen(& ...
- 利用顺序栈解决括号匹配问题(c++)-- 数据结构
题目: 7-1 括号匹配 (30 分) 给定一串字符,不超过100个字符,可能包括括号.数字.字母.标点符号.空格,编程检查这一串字符中的( ) ,[ ],{ }是否匹配. 输入格式: 输入在一行 ...
- 《LeetBook》leetcode题解(20):Valid Parentheses[E]——栈解决括号匹配问题
我现在在做一个叫<leetbook>的免费开源书项目,力求提供最易懂的中文思路,目前把解题思路都同步更新到gitbook上了,需要的同学可以去看看 书的地址:https://hk029.g ...
- Python面试题:使用栈处理括号匹配问题
括号匹配是栈应用的一个经典问题, 题目 判断一个文本中的括号是否闭合, 如: text = "({[({{abc}})][{1}]})2([]){({[]})}[]", 判断所有括 ...
- 利用栈实现括号匹配(python语言)
原理: 右括号总是与最近的左括号匹配 --- 栈的后进先出 从左往右遍历字符串,遇到左括号就入栈,遇到右括号时,就出栈一个元素与其配对 当栈为空时,遇到右括号,则此右括号无与之匹配的左括号 当最终右括 ...
- 栈之括号匹配问题(java实现)
假设表达式中只允许两种括号:().{}:正确表达顺序为:()或{}或({})或{({}{})}的形势:如{(}或(})或({)}的表达形势均不对.算法的设计思想: 出现左括弧则进栈: 出现右括弧则首先 ...
随机推荐
- Python 技巧(三)—— list 删除一个元素的三种做法
我们以一个字符串为元素类型的 list 为例,进行列表元素的删除: >>> l = ['no surfing', 'flippers'] 1 法一:remove(val) >& ...
- 线段树[To be continued]
目录 数据结构--线段树 一.定义 二.性质 三.基本操作 0.结构体 1.建树 2.单点查询 3.单点修改 4.区间修改 5.区间查询 四.题目 单点修改.区域查询模板 五.鸣谢 学姐的Blog 百 ...
- axure rp教程(四)动态面板滑动效果
转载自: http://www.iaxure.com/74.html 实现目标: 1. 点击登录滑出登录面板 2. 点击确定滑出动态面板 最终效果如下: 这种效果可以通过两种方法实现: 首先准备需 ...
- jxl教程图文详解
近来学习了下jxl的操作Excel报表功能,现有的API基本可以满足当前的需要,抽空做了一个学生成绩查询报表的例子. 先看效果图: 从图中可以看到这是一个交叉报表,横向到Q列,纵向有22行,全部是通过 ...
- 嵌入式之download
ISP ISP(In-System Programming)在系统可编程,指电路板上的空白器件可以编程写入最终用户代码, 而不需要从电路板上取下器件,已经编程的器件也可以用ISP方式擦除或再编程.IS ...
- c#每循环100次提交一次数据,最后一次不足100次提交一次
StringBuilder sb=new StringBuilder(); string strId=dataGridView1.Rows[dataGridView1.CurrentRow.Index ...
- 替换掉 in的like操作
select * from t_unit where '410300060025,410300004005,410300998851,' like '%'+ltrim(rtrim(unitcode)) ...
- sqlserver创建存储过程返回table
--创建存储过程test create procedure [dbo].[test] ( @I_MTR NVARCHAR (MAX), @I_TYPE NVARCHAR (MAX), @I_FAC N ...
- Scala学习之路----基础入门
一.Scala解释器的使用 REPL:Read(取值)-> Evaluation(求值)-> Print(打印)-> Loop(循环) scala解释器也被称为REPL,会快速编译s ...
- HDU 4786 最小生成树变形 kruscal(13成都区域赛F)
Fibonacci Tree Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...