括号匹配加强版

描述 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:括号匹配加强版的更多相关文章

  1. STL-stack和顺序栈实现括号匹配

    2018-11-11-14:28:31 1.顺序栈 下面是我用数组实现的顺序栈,包含的函数有出入栈,查看栈顶元素,栈的大小,栈是否空等函数,当栈空间不够用时,对应的数组会自动增长. /******** ...

  2. HDU 4283 You Are the One ★(进出栈的括号匹配性质:区间DP)

    题意 有一个队列,每个人有一个愤怒值D,如果他是第K个上场,不开心指数就为(K-1)*D.但是边上有一个小黑屋(一个FILO堆栈),可以一定程度上调整上场程序,求一种安排上场方案使得所有人的不开心指数 ...

  3. OJP1147括号匹配加强版(栈)与P1153乱头发节(单调栈)

    惨兮兮的被刷掉2%的通过率后在经过思考和dalao的指点后终于A掉了这道题 强烈建议修改这题的样例,实在太迷惑人,各种错误算法都能过 比如说这是一份错误代码,看懂了也不要学思路,和正解不知道差到哪里去 ...

  4. C语言数据结构之栈:括号匹配

    括号匹配这是个很简单的题目,如果只有小括号,就模拟进栈和出栈的过程就行了: 注:输入时'@'作为结束标志 #include <stdio.h> int main() { freopen(& ...

  5. 利用顺序栈解决括号匹配问题(c++)-- 数据结构

    题目: 7-1 括号匹配 (30 分)   给定一串字符,不超过100个字符,可能包括括号.数字.字母.标点符号.空格,编程检查这一串字符中的( ) ,[ ],{ }是否匹配. 输入格式: 输入在一行 ...

  6. 《LeetBook》leetcode题解(20):Valid Parentheses[E]——栈解决括号匹配问题

    我现在在做一个叫<leetbook>的免费开源书项目,力求提供最易懂的中文思路,目前把解题思路都同步更新到gitbook上了,需要的同学可以去看看 书的地址:https://hk029.g ...

  7. Python面试题:使用栈处理括号匹配问题

    括号匹配是栈应用的一个经典问题, 题目 判断一个文本中的括号是否闭合, 如: text = "({[({{abc}})][{1}]})2([]){({[]})}[]", 判断所有括 ...

  8. 利用栈实现括号匹配(python语言)

    原理: 右括号总是与最近的左括号匹配 --- 栈的后进先出 从左往右遍历字符串,遇到左括号就入栈,遇到右括号时,就出栈一个元素与其配对 当栈为空时,遇到右括号,则此右括号无与之匹配的左括号 当最终右括 ...

  9. 栈之括号匹配问题(java实现)

    假设表达式中只允许两种括号:().{}:正确表达顺序为:()或{}或({})或{({}{})}的形势:如{(}或(})或({)}的表达形势均不对.算法的设计思想: 出现左括弧则进栈: 出现右括弧则首先 ...

随机推荐

  1. Linuxshell编程

    重点回顾: 1.由于核心的内存中是受保护的区块,因此我们必须要透过“shell”将我们输入的指令与Kernel沟通,好让Kernel可以控制硬件来正确无误的工作 2.学习shell的原因主要有:文字接 ...

  2. CentOS6.5创建yum源

    昨天给布置个新的需求,做一个Yum仓库,要求是HTTP式的,在某个服务器上搭建个Yum仓库,能让其它的机器有了这个机器的.repo仓库文件后就可以从本地下载安装软件,以前都是下载后直接yum inst ...

  3. linux环境搭建系列之Apache ant安装步骤

    前提: linux centOS6.6 64位操作系统 ROOT账号 JDK1.7 注意:JDK和Ant版本一定要是对应的,因为我的JDK是1.7版本的,所以我在官网下载的ant是1.9的 1.把安装 ...

  4. 微信小程序-----校园头条详细开发之列表展示数据

    1.分类列表数据展示功能的实现 1.1 结构 1.2 代码实现 1.2.1  列表显示数据,.每次界面显示6条数据,发请求获取数据,动态存放 var app = getApp() Page({ dat ...

  5. python 学习分享-实战篇选课系统

    # 角色:学校.学员.课程.讲师 # 要求: # 1. 创建北京.上海 2 所学校 # 2. 创建linux , python , go 3个课程 , linux\py 在北京开, go 在上海开 # ...

  6. python学习-- Django Ajax CSRF 认证

    使用 jQuery 的 ajax 或者 post 之前 加入这个 js 代码:http://www.ziqiangxuetang.com/media/django/csrf.js /*======== ...

  7. html编码和解码

    public static string EncodeStr(string str) { str = Regex.Replace(str, @"<html[^>]*?>.* ...

  8. python 打印9*9乘法表

    # -*- coding: utf8 -*- # Author:wxq 1. for i in range(1,10): for j in range(1,i+1): print "%d*% ...

  9. 单元测试-mock基础

    本文较短,只是备份一下mock的几个常用基础例子方便复习 目录 介绍mock的使用例子 maven资源 <dependency> <groupId>org.mockito< ...

  10. hihoCoder #1758 加减

    $\DeclareMathOperator{\lowbit}{lowbit}$ 题目大意 对于一个数 $x$,设它最低位的 1 是第 $i$ 位,则 $\lowbit(x)=2i$ . 例如 $\lo ...