leetcode 20.有效的括号 Java

  • Post author:
  • Post category:java




题目链接


https://leetcode-cn.com/problems/valid-parentheses/



描述

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

有效字符串需满足:

左括号必须用相同类型的右括号闭合。

左括号必须以正确的顺序闭合。

注意空字符串可被认为是有效字符串。



示例

示例1

输入: "()"
输出: true

示例2

输入: "()[]{}"
输出: true

示例3

输入: "(]"
输出: false

示例4

输入: "([)]"
输出: false

示例5

输入: "{[]}"
输出: true



代码



栈 (时间复杂度O(N),空间复杂度O(N))

class Solution {
    public boolean isValid(String s) {
        Deque<Character> stack = new LinkedList<>();

        //防止循环判定时为空的情况
        //否则 stack.pop() != c 要改为 stack.isEmpty() || stack.pop() != c,加个字符减少判定
        stack.push('-');

        for (int i = 0; i < s.length(); i++){
            char c = s.charAt(i);

            if (c == '('){
                stack.push(')');
            } else if (c == '[') {
                stack.push(']');
            } else if (c == '{') {
                stack.push('}');
            } else if (stack.pop() != c){
                return false;
            }
        }

        return stack.size() == 1;
    }
}



版权声明:本文为qq_43349112原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。