数据结构之栈的括号匹配问题

博客探讨了如何检查字符串中的括号是否匹配,通过遍历字符串并利用栈数据结构来判断左括号和右括号的配对情况。文章提供了C++的代码示例,并展示了不同输入的运行结果。
摘要由CSDN通过智能技术生成

问题描述

任意给定一个字符串,字符串中包含除了空格、换行符之外的任意字符。检测字符串中的各类括号是否配对,即“(”与“)”、“[”与“]”、“{”与“}”是否匹配。若匹配输出对应的匹配个数。

输入描述

一行字符串。

输出描述

如果字符串中的括号匹配,则输出数字 1,并且在下一行输出{}、[]、()相对应的匹配个数,否则输出数字 0。

示例

输入:
&()dgn*[{%}12]
输出:
3

输入:
12(%]{
输出:
0

解题思路

这道题目在很多考研试卷中出过,或者是算法题,或者是简答题。遍历字符串,遇到左括号进栈,遇到右括号则判断是否与栈顶的左括号相匹配,匹配则栈顶元素出栈,否则跳过。

相关代码

本题目直接使用C++中的栈( s t a c k stack stack)类来解答,省去了 p o p pop pop

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值