括号配对问题描述输入输出样例输入样例输出解析代码实现运行结果参考链接

括号配对问题-题目链接

描述

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

输入

第一行输入一个数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;
        }
    }
}

运行结果

运行结果

参考链接

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏技术博客

JavaScript定时调用函数(SetInterval与setTimeout)

setTimeout和setInterval的语法相同。它们都有两个参数,一个是将要执行的代码字符串,还有一个是以毫秒为单位的时间间隔,当过了那个时间段之后就将...

26740
来自专栏对角另一面

读Zepto源码之Selector模块

Selector 模块是对 Zepto 选择器的扩展,使得 Zepto 选择器也可以支持部分 CSS3 选择器和 eq 等 Zepto 定义的选择器。 在阅读本...

21300
来自专栏与神兽党一起成长

手工实现表单重置的部分功能

首先我必须说几乎所有的人都不需要自己实现表单重置的功能,表单重置功能只需要一个reset类型的input就足够了。<input type="reset" />

18630
来自专栏分布式系统和大数据处理

Go语言Tips

转型到Go以后,因为语言的不熟悉,以往很常见的一些操作有时候也需要去Google一下。这里将一些结果记录下来,方便日后查阅。

15420
来自专栏大前端_Web

jquery常用函数及技巧(持续更新)

版权声明:本文为吴孔云博客原创文章,转载请注明出处并带上链接,谢谢。 https://blog.csdn.net/wkyseo/articl...

14310
来自专栏软件开发

前端MVC Vue2学习总结(三)——模板语法、过滤器、计算属性、观察者、Class 与 Style 绑定

Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据。所有 Vue.js 的模板都是合法的 HTML ,...

657100
来自专栏互联网软件技术

将表格导出为excel

13050
来自专栏源码之家

EXCEL取消合并且等于原合并值

16540
来自专栏青青天空树

小程序报错数据传输长度为 xxx 已经超过最大长度 xxx

 这个错误通常在通过base64给images赋值时发生,setData()微信设置的一次最大传输长度为1M,所有如果编码后的base64字符串长度超过了1M就...

40110
来自专栏MixLab科技+设计实验室

设计师编程指南之Sketch插件开发 9 之 Shape中的oval

往期文章索引: 1 / 入门基本概念、page的相关操作 2 / artboard 、NSFileManager 和 NSString 关于文件及文件夹的相关操...

32470

扫码关注云+社区

领取腾讯云代金券