[leetcode] 20. 有效的括号

Posted ACBingo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[leetcode] 20. 有效的括号相关的知识,希望对你有一定的参考价值。

20. 有效的括号

括号匹配,用栈即可。高中时第一次学栈后做的第一个题。。

class Solution {
    public boolean isValid(String s) {
        Stack<Character> characterStack = new Stack<>();

        for (int i = 0; i < s.length(); i++) {
            switch (s.charAt(i)) {
                case ‘(‘:
                case ‘[‘:
                case ‘{‘:
                    characterStack.push(s.charAt(i));
                    break;
                case ‘)‘:
                    if (!characterStack.isEmpty() && characterStack.peek() == ‘(‘) {
                        characterStack.pop();
                        break;
                    } else {
                        return false;
                    }
                case ‘]‘:
                    if (!characterStack.isEmpty() && characterStack.peek() == ‘[‘) {
                        characterStack.pop();
                        break;
                    } else {
                        return false;
                    }
                case ‘}‘:
                    if (!characterStack.isEmpty() && characterStack.peek() == ‘{‘) {
                        characterStack.pop();
                        break;
                    } else {
                        return false;
                    }
            }
        }

        return characterStack.isEmpty();
    }
}

以上是关于[leetcode] 20. 有效的括号的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode 20. 有效的括号

leetcode20有效的括号

LeetCode第20题——有效的括号

LeetCode:有效的括号20

leetcode-20.有效的括号

LeetCode 20. 有效的括号