栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

栈的应用:括号匹配

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

栈的应用:括号匹配

给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。

栈的结构非常适合做对称匹配类题目。要解决这个问题,首先需要清楚字符串括号不匹配有几种情况:

(1)字符串左方向的括号多,此种情况下遍历完字符串栈内不为空。

(2)括号没有出现多余,但是类型不匹配。

(3)字符串右方向的括号多,这种情况下匹配过程中栈内元素不够。

完整代码如下:

//有效的括号 
bool isValid(string s) {
    if (s.size() % 2 != 0) return false;
    if(s[0] == ')' || s[0] == ']' || s[0] == '}') return false;
    int t = 1; //标记是否匹配 
    stack st;
     
    for(int i = 0; i
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/718033.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号