栈练习--------有效的括号(LeetCode 20)

题目:点这里

解法

cpp 复制代码
class Solution {
public:
    bool isLeft(char a){
        if(a=='('||a=='{'||a=='['){
            return true;
        }else{
            return false;
        }
    }
    bool isMatch(char a,char b){
        if(a=='['&&b==']'||a=='{'&&b=='}'||a=='('&&b==')'){
            return true;
        }else{
            return false;
        }
    }
    bool isValid(string s) {
        int size = s.size();
        stack<char> st;
        for(int i=0;i<size;i++){
            if(isLeft(s[i])){//左括号
                st.push(s[i]);
            }
            else{//右括号
                if(st.empty()){//为空则匹配失败
                    return false;
                }
                if(!isMatch(st.top(),s[i])){//匹配失败则返回false
                return false;
                }
            st.pop();
            }
            
        }
        if(st.empty()){
            return true;
        }else{
            return false;
        }
    }
};

这个题目给我带来了栈的初步运用,因为我做之前那些题目一直觉得栈的存在感很低,跟链表和顺序表差不多,区分不开,现在这个题目恰恰体现了栈的作用,它不是一种底层的结构,它是一种思想。

这个题目也叫做括号消消乐,我们的栈巧妙地解决这个问题,保证相同括号两两匹配,而且保证顺序正确。

思路就是首先定义两个函数,一个负责判断左括号,一个负责匹配左括号和右括号,在题目给定的函数中,首先判断是否是左括号,利用函数1,是则输入到我们定义的栈里面去,然后如果不是左括号,那就是右括号,在else 语句中,咱们首先if 语句判断栈是否为空,如果是,那就简单了,没有与之匹配的左括号,直接返回false就好了,然后再用另一个if语句判断栈顶的左括号是否能够和这个右括号匹配,如果可以则弹出栈顶元素,这样的话,利用for循环,等待遍历结束,如果栈为空,则所有括号都两两配对成功,返回true,否则存在未配对的左括号,返回false.

这个栈利用地精妙绝伦,精妙之处在于,它可以完美地完成括号的消消乐,我举个例子,

{}() , ({}) , {(}),这三个里面,传入一个元素后紧接着就可以和右括号匹配,第二个传入两个,随着弹栈,依然可以一一匹配,第三个恰好不行,妙哉。

相关推荐
会编程的土豆27 分钟前
【数据结构与算法】再次全面了解LCS底层
开发语言·数据结构·c++·算法
低频电磁之道30 分钟前
解决 Windows C++ DLL 导出类不可见的编译错误
c++·windows
君义_noip2 小时前
信息学奥赛一本通 4150:【GESP2509七级】⾦币收集 | 洛谷 P14078 [GESP202509 七级] 金币收集
c++·算法·gesp·信息学奥赛·csp-s
Ricky_Theseus2 小时前
静态链接与动态链接
c++
摸个小yu2 小时前
【力扣LeetCode热题h100】链表、二叉树
算法·leetcode·链表
汀、人工智能2 小时前
[特殊字符] 第93课:太平洋大西洋水流问题
数据结构·算法·数据库架构·图论·bfs·太平洋大西洋水流问题
澈2073 小时前
双指针,数组去重
c++·算法
小辉同志3 小时前
207. 课程表
c++·算法·力扣·图论
feng_you_ying_li3 小时前
C++11,{}的初始化情况与左右值及其引用
开发语言·数据结构·c++
锅挤4 小时前
数据结构复习(第一章):绪论
数据结构·算法