20. 有效的括号

2022-02-25  本文已影响0人  Abeants

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

有效字符串需满足:

示例 1:
输入:s = "()"
输出:true

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

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

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

示例 5:
输入:s = "{[]}"
输出:true

提示:
1 <= s.length <= 104
s 仅由括号 '()[]{}' 组成

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/valid-parentheses
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路及方法

比较经典的算法,用栈去匹配。之前先预先判断,如果字符串长度为奇数则肯定不满足。

class Solution {
    public boolean isValid(String s) {
        if (s.length() % 2 == 1) return false;
        Stack<Character> stack = new Stack<>();

        for (int i = 0; i < s.length(); i++) {
            char cur = s.charAt(i);
            // 空栈字符入栈
            if (stack.isEmpty()) {
                stack.push(cur);
            } else {
                char top = stack.peek();
                // 括号匹配则栈顶字符出栈,否则当前字符入栈
                if (top == '(' && cur == ')') stack.pop();
                else if (top == '[' && cur == ']') stack.pop();
                else if (top == '{' && cur == '}') stack.pop();
                else stack.push(cur);
            }
        }
        
        return stack.isEmpty();
    }
}

结果如下:

上一篇下一篇

猜你喜欢

热点阅读