OJ1147括号匹配加强版(栈)

惨兮兮的被刷掉2%的通过率后在经过思考和dalao的指点后终于A掉了这道题

强烈建议修改这题的样例,实在太迷惑人,各种错误算法都能过

比如说这是一份错误代码,看懂了也不要学思路,和正解不知道差到哪里去了:

惨兮兮,WA掉代码:

#include <iostream>

#include <iomanip>

#include <cmath>

#include <cstdio>

#include <cstring>

#include <algorithm>

#include <ctime>

using namespace std;

char a[100086];

int len,top=0,ll=0,lexn,maxx=-10000,leen;

char s[100086],bb[10086],jg[100086];

bool f=true;

int main()

{

memset(a,0,sizeof(a));

memset(s,0,sizeof(s));

cin>>a;

len=strlen(a);

for(int i=0;i<len;i++)

{

if(s[top]==‘(‘)

{

if(a[i]==‘]‘)

{memset(s,0,sizeof(s));memset(bb,0,sizeof(bb));top=0;f=false;}

else if(a[i]==‘(‘)

{

s[++top]=a[i];

bb[++ll]=a[i];

}

else if(a[i]==‘)‘)

{

bb[++ll]=a[i];

top--;

}

}

else if(s[top]==‘[‘)

{

if(a[i]==‘)‘)

{memset(s,0,sizeof(s));memset(bb,0,sizeof(bb));top=0;f=false;}

else if(a[i]==‘(‘)

{

s[++top]=a[i];

bb[++ll]=a[i];

}

else if(a[i]==‘]‘)

{

bb[++ll]=a[i];

top--;

}

}

else if(a[i]==‘(‘||a[i]==‘[‘)

{s[++top]=a[i];bb[++ll]=a[i];}

if(top==0&&f)

{

//lexn=strlen(bb);

if(maxx<ll)

{

memset(jg,0,sizeof(jg));

maxx=ll;

if(leen!=maxx)

leen=0;

for(int i=1;i<=ll;i++)

{

jg[i]=bb[i];

leen++;

}

}

ll=0;

memset(bb,0,sizeof(bb));

memset(s,0,sizeof(s));

}

if(!f)

f=true;

}

for(int i=1;i<=leen;i++)

{

if(jg[i]==‘[‘||jg[i]==‘(‘||jg[i]==‘]‘||jg[i]==‘)‘)

cout<<jg[i];

}

return 0;

}(这是WA掉的)

但即便是这个WA掉所有数据的错误代码都能过样例,所以改一下为好吧……

然后是正解思路:

读入一个char型数组,然后将此数组中的字符挨个进栈,如果碰到’]’或是’)’,就查看栈顶元素,如果是能与当前字符匹配的左括号,就进栈,bool型数组标记,否则就将栈清空,操作讲不清,代码如下:

#include <iostream>

#include <iomanip>

#include <cstdio>

#include <cmath>

#include <cstring>

#include <ctime>

#include <algorithm>

using namespace std;

int len,s=0,maxx=-1000,top=-1,sum=-1,num=-1,t=0;//top为栈顶下标,因为是字符串,所以为-1,sum,num同理

char a[1000086],stack[1000086];

bool f[1000086];

int d[1000010],e[1000010];//开两个数组分别记录‘(‘和‘]‘的下标

int main()

{

cin>>a;

memset(f,false,sizeof(f));

len=strlen(a);

for(int i=0;i<len;i++)

{

stack[++top]=a[i];//入栈

if(stack[top]==‘(‘)//当栈顶是(时,记录下标

d[++sum]=i;

if(stack[top]==‘[‘)//同上

e[++num]=i;

if((stack[top]==‘)‘&&stack[top-1]==‘[‘)||(stack[top]==‘]‘&&stack[top-1]==‘(‘))//当右括号与栈顶左括号不匹配时,栈清空

top=0;

else if((stack[top]==‘)‘&&stack[top-1]==‘(‘)||(stack[top]==‘]‘&&stack[top-1]==‘[‘))//当栈顶左括号与右括号匹配时

{

f[i]=1;//标记当前下标

if(stack[top]==‘]‘)//如果栈顶右括号为]?

{

f[e[num]]=1;//bool数组标记下标

num--;//存储]的数组减去一个]

}

if(stack[top]==‘)‘)//理同上

{

f[d[sum]]=1;

sum--;

}

top-=2;//因为左括号与右括号匹配,所以直接删去两个

}

}

for(int i=0;i<len;i++)

{

if(f[i])//t为能够匹配的括号式的长度

t++;

else//因为匹配括号式必须挨着,所以一旦!f[i],则说明已经记录完了一个括号式

{

if(t>maxx)//标记最大长度

{

maxx=t;

s=i;//s记录当前下标

}

t=0;

}

}

if(t>maxx)//避免式子在最后

{

maxx=t;

s=len;

}

for(int i=s-maxx;i<s;i++)//s减去maxx即为最长表达式的起始下标

cout<<a[i];

return 0;

}

时间: 2024-10-13 03:07:28

OJ1147括号匹配加强版(栈)的相关文章

jzyzoj 栈——P1148:括号匹配加强版

括号匹配加强版 描述 Description 对于一个由(,),[,]括号组成的字符串,求出其中最长的括号匹配字串. 具体来说,满足如下条件的字符串成为括号匹配的字符串: (1) (),[] 是括号匹配的字符串. (2) 若A是括号匹配的串,则(A)或[A] 是括号匹配的字符串. (3) 若A和B都是括号匹配的字符串,则A+B也是括号匹配的字符串.(这里的+是字符串的加法运算). 例如:(),[],([]),()() 都是括号匹配的字符串,而][,[( ]),(]则不是. 字符串A的子串是指由A

算法学习 - 括号匹配(栈实现)C++

括号匹配是栈最典型的应用了. 其实思路很简单,就是遇到一个左括号就压栈,遇到一个右括号就弹栈,看是否匹配就好了.最后检查下栈里是不是有剩余的括号就行了. 上代码~: // // main.cpp // bracketMatch // // Created by Alps on 14-7-28. // Copyright (c) 2014年 chen. All rights reserved. // #include <iostream> #define ElementType char usi

括号匹配的栈实现

括号匹配的栈实现 问题:判断一个文本中,括号是否匹配? 思路:从头到尾扫描字符串,每次遇到左括号(如'(', '[', '{')就压入堆栈,如果遇到右括号(如')', ']', '}')就与栈顶元素比较,如果成对,OK,否则判断不匹配. 代码如下: #include <iostream> #include <stack> #include <set> #include <string> using namespace std; /* * vaild retu

括号匹配(链栈实现)

/* 建立链栈实现括号匹配问题 创建栈,判断是否空栈 */ #include<stdio.h> #include<stdlib.h> #include<string.h> #define status int typedef struct node { char ch; node* next; }SNode; typedef struct { SNode *top; //SNode *base; }Stack; //创建空栈 base 赋值为NULL, top 指向栈顶

顺序栈(进制转换 + 括号匹配 + 判断栈表 + 最长括号匹配长度)

#include <stdio.h> #include <stdlib.h> #include <iostream> using namespace std; #define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 #define INFEASIBLE -1 #define OVERFLOW -2 #define STACK_INIT_SIZE 100 #define STACKLINCREMENT 10

题目1153:括号匹配问题(栈的使用)

题目链接:http://ac.jobdu.com/problem.php?pid=1153 详解链接:https://github.com/zpfbuaa/JobduInCPlusPlus // // 1153 括号匹配问题.cpp // Jobdu // // Created by PengFei_Zheng on 08/04/2017. // Copyright © 2017 PengFei_Zheng. All rights reserved. // #include <stdio.h>

表达式括号匹配(栈)

1386: 表达式括号匹配 时间限制: 1 Sec  内存限制: 128 MB提交: 12  解决: 9[提交][状态][讨论版] 题目描述 假设一个表达式有英文字母(小写).运算符(+,-,*,/)和左右小(圆)括号构成,以"@"作为表达式的结束符.请编写一个程序检查表达式中的左右圆括号是否匹配,若匹配,则返回"YES":否则返回"NO".表达式长度小于255,左圆括号少于20个. 输入 包括一行数据,即表达式 输出 包括一行,即"Y

括号匹配(栈)

检查一段C语言代码的小括号( ). 中括号 [ ] 和大括号{ } 是否匹配. 输入格式: 在一行中输入一段C语言代码,长度不超过1000个字符(行末以换行符结束). 输出格式: 第一行输出左括号的数量和右括号的数量,中间以一个空格间隔.若括号是匹配的,在第二行打印YES,否则打印NO. 输入样例1: for(int i=0; i<v; i++){ visited[i] = 0; for(int j=0; j<v; j++) scanf("%d",&(g->A

括号匹配--java栈实现

假设括号都是(),{},[],{[]()},{()()}这种可以匹配的,存在{(}),([)均为错. 1 public boolean match(String str) { 2 //String str="[()()]{}"; 3 Stack <Character> s = new Stack<Character>(); 4 for (int index=0; index<str.length();index++) { 5 switch(str.char