【图解】leetcode热题HOT100之Java实现:有效的括号,栈匹配括号

1、题目描述

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

有效字符串需满足:

①  左括号必须用相同类型的右括号闭合。
②  左括号必须以正确的顺序闭合。

2、算法思想

   ①  使用栈存储匹配括号的相对应匹配括号

   ②  遍历字符串,预定将对应的括号放入栈中,然后遍历出的值和栈顶的值做对比

   ③  返回栈的true或者false;

   1,如果遇到了左括号,就把对应的右括号压栈(比如遇到了字符'(',就把字符')'压栈)。

    2,如果遇到了右括号

      1)查看栈是否为空,如果为空,说明不能构成有效的括号,直接返回false。

      2)如果栈不为空,栈顶元素出栈,然后判断出栈的这个元素是否等于这个右括号,如果不等于,说明不匹配,直接返回false。如果匹配,就继续判断字符串的下一个字符
    3,最后如果栈为空,说明是完全匹配,是有效的括号,否则如果栈不为空,说明不完全匹配,不是有效的括号。

图解:

4、代码实现

public boolean isValid(String s) {

    // 定义一个栈,存储匹配的括号元素
    Stack<Character> stack = new Stack<>();
    char[] chars = s.toCharArray();
    
    // 说明字符串里的符号不成对出现
    if(chars.length % 2 == 1){
        return false;
    }

    //遍历所有的元素
    for (char c : chars) {

        //如果是左括号,就把他们对应的右括号压栈
        if (c == '(') {
            stack.push(')');
        } else if (c == '{') {
            stack.push('}');
        } else if (c == '[') {
            stack.push(']');
        } else if (stack.isEmpty() || stack.pop() != c) {

            //否则就只能是右括号。
            //1,如果栈为空,说明括号无法匹配。
            //2,如果栈不为空,栈顶元素就要出栈,和这个右括号比较。
            //如果栈顶元素不等于这个右括号,说明无法匹配,
            //直接返回false。
            return false;
        }
    }

    //最后如果栈为空,说明完全匹配,是有效的括号。
    //否则不完全匹配,就不是有效的括号
    return stack.isEmpty();
}

猜你喜欢

转载自blog.csdn.net/Sunshineoe/article/details/115221849
今日推荐