前言

哈喽,我是长路,目前刚刚大三,方向是后端也偶尔捣鼓下前端,现在的主语言是Java。之前一大段时间都是在学习web开发的一些技术,就很久没有进行类似于数据结构、算法之类的学习与刷题,打算这段时间拾起来好好学一学、搞一搞。

这段时间也是机缘巧合看到草帽路飞的博客,加了自学群,正巧看到博主组织在群里组织了leetcode刷题打卡活动,我也就参与进来,为期一个月,打算坚持每天都花一些时间做一些题目,并通过博客的方式来进行记录。

目前跟着一个Github仓库刷题(leetcode):代码随想录leetcode刷题,当前为栈与队列专题。



题目

题目来源leetcode

leetcode地址:20. 有效的括号,难度:简单。

题目描述(摘自leetcode):

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

有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
 
示例 1:
输入:s = "()"
输出:true

示例 2:
输入:s = "()[]{}"
输出:true

示例 3:
输入:s = "(]"
输出:false

示例 4:
输入:s = "([)]"
输出:false

示例 5:
输入:s = "{[]}"
输出:true
 
提示:
1 <= s.length <= 104
s 仅由括号 '()[]{}' 组成

本地调试代码:

class Solution {
    public int search(int[] nums, int target) {
        ....
    }
    
    public static void main(String[] args) {
        Solution solution = new Solution();
        int[] arr = new int[]{-1,0,3,5,9,12};//这里修改数组内容
        System.out.println(solution.search(arr, 2));//数组、目标值
    }
}


题解

NO1:栈解决

思路:若是左闭合符号就压入配对的右闭合符号,方便之后进行匹配。

示例:"()[{}]"   stack=[]
① 字符'(',压入')'  stack=['(']
② 字符')',与当前栈顶存放匹配,出栈  stack=[]
③ 字符'[',压入']'  stack=[']']
④ 字符'{',压入'}'  stack=[']','}']
⑤ 字符'}',与当前栈顶存放匹配,出栈 stack=[']']
⑥ 字符']',与当前栈顶存放匹配,出栈 stack=[]
所有字符都遍历一遍之后,判断栈中是否存在元素,为空表示有效括号;不为空表示无效括号。

代码

public boolean isValid(String s) {
    Deque<Character> stack = new LinkedList<>();
    for (char c : s.toCharArray()) {
        //前面三个判断当匹配到左闭合时存储右闭合符号到栈,之后用来进行直接匹配
        if(c == '('){
            stack.push(')');
        }else if(c == '{'){
            stack.push('}');
        }else if(c == '['){
            stack.push(']');
        }else if(stack.isEmpty() || stack.peek() != c){ //若是栈为空或者对应匹配的不一致,直接判定不匹配
            return false;
        }else {
            stack.pop();
        }
    }
    //若是为空,表示全部匹配完了,若是没有空说明另外少了右闭合括括号
    return stack.isEmpty();
}

leetcode【栈与队列—简单】 20. 有效的括号_leetcode



参考文章

[1]. leetcode题解

[2]. 代码随想录—有效的括号


我是长路,感谢你的耐心阅读。如有问题请指出,我会积极采纳!
欢迎关注我的公众号【长路Java】,分享Java学习文章及相关资料
Q群:851968786 我们可以一起探讨学习
注明:转载可,需要附带上文章链接