括号配对问题

简介: 括号配对问题

括号配对问题-题目链接


描述


现在,有一行括号序列,请你检查这行括号是否配对。


输入


第一行输入一个数N(0<N<=100),表示有N组测试数据。后面的N行输入多组输入数据,每组输入数据都是一个字符串S(S的长度小于10000,且S不是空串),测试数据组数少于5组。数据保证S中只含有"[","]","(",")"四种字符


输出


每组输入数据的输出占一行,如果该字符串中所含的括号是配对的,则输出Yes,如果不配对则输出No


样例输入


3
[(])
(])
([[]()])


样例输出


No
No
Yes


解析


  • 顺序扫描括号字符串中每一个字符,当遇到栈空或者遇到左括号时该括号进栈;
  • 当扫描到某一种类型的右括号时,比较当前栈顶元素是否与之匹配,若匹配,出栈继续判断;
  • 若当前栈顶元素与当前扫描的右括号括号不匹配,则将该右括号进栈(此时已经匹配失败);
  • 若最终栈为空,则括号匹配成功,如果不为空,则不成功;


代码实现


#include<iostream>
#include<stack>
#include<string>
using namespace std;
int main(){
    int n;
    cin>>n;
    while(n--){
        stack<char> s;
        string ch;
        cin>>ch;
        for(int i=0;i<ch.length();i++){
            if(s.empty()){//如果栈为空继续进栈
                s.push(ch[i]);
            }else{
                if(ch[i]=='('||ch[i]=='[') s.push(ch[i]);
                else{
                    if(ch[i]==')'){
                        if(s.top()=='(')s.pop();
                        else s.push(ch[i]);
                    }
                    if(ch[i]==']'){
                        if(s.top()=='[')s.pop();
                        else s.push(ch[i]);
                    }
                }
            }
        }
        if(s.empty()){
            cout<<"Yes"<<endl;
        }else{
            cout<<"No"<<endl;
        }
    }
}


运行结果


5.png

运行结果


参考链接


[NYOJ] 02括号配对问题(c语言链栈实现)


相关文章
|
4月前
|
算法 测试技术 C#
【字符串】【括号匹配】【广度优先】301. 删除无效的括号
【字符串】【括号匹配】【广度优先】301. 删除无效的括号
【字符串】【括号匹配】【广度优先】301. 删除无效的括号
|
4月前
|
C++
HRBUST - 1170(判断括号是否匹配)
HRBUST - 1170(判断括号是否匹配)
|
4月前
C的if...else..配对
C的if...else..配对
14 0
|
存储 算法
算法训练day11|20. 有效的括号;1047. 删除字符串中的所有相邻重复项;150. 逆波兰表达式求值
算法训练day11|20. 有效的括号;1047. 删除字符串中的所有相邻重复项;150. 逆波兰表达式求值
蓝桥——括号合法组合 2020-11-26
蓝桥——括号合法组合 2020-11-26
|
算法 前端开发 JavaScript
【前端算法】判断一个字符串的括号是否成对匹配
使用typescript完成判断一个字符串的括号是否成对匹配的过程
120 0
089.配对新郎和新娘
089.配对新郎和新娘
100 0
|
前端开发 JavaScript 算法
有效的括号,成对字符合法性检测
每日算法练习,今天一起来看看“有效的括号,成对字符合法性检测”。
252 0
括号有效配对一箭三连(三)
1) 任何一个左括号都能找到和其正确配对的右括号 2) 任何一个右括号都能找到和其正确配对的左括号 返回一个括号字符串中,最长的括号有效子串长度
146 0