括号配对问题

简介: 括号配对问题

括号配对问题-题目链接


描述


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


输入


第一行输入一个数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语言链栈实现)


相关文章
|
9月前
|
算法 前端开发
最大字符串配对数目
最大字符串配对数目
39 0
|
9月前
|
C++
HRBUST - 1170(判断括号是否匹配)
HRBUST - 1170(判断括号是否匹配)
|
9月前
|
存储
leetcode2744. 最大字符串配对数目
leetcode2744. 最大字符串配对数目
48 0
|
存储 算法
算法训练day11|20. 有效的括号;1047. 删除字符串中的所有相邻重复项;150. 逆波兰表达式求值
算法训练day11|20. 有效的括号;1047. 删除字符串中的所有相邻重复项;150. 逆波兰表达式求值
|
编译器 C语言
【C操作符详解】之 移位操作符
【C操作符详解】之 移位操作符
120 0
|
数据安全/隐私保护 Python
一日一技:一个括号两种意思,正则表达式奇怪的小括号
一日一技:一个括号两种意思,正则表达式奇怪的小括号
100 0
用户输入括号是否匹配
用户输入括号是否匹配
91 0
|
C语言
符号配对 (20 分)
符号配对 (20 分)
220 0
C++学习——c++逗号操作符说明(附加全部运算符优先级)
C++学习——c++逗号操作符说明(附加全部运算符优先级)
220 0
C++学习——c++逗号操作符说明(附加全部运算符优先级)