LeetCode-20-有效的括号

本文解析了如何通过栈和哈希表实现对只包含括号的字符串的有效性检查,涉及遍历、匹配、栈操作和空间优化。核心思路是利用栈来跟踪左括号,确保正确闭合。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目

来源:LeetCode.

给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。
有效字符串需满足:
1.左括号必须用相同类型的右括号闭合。
2.左括号必须以正确的顺序闭合。

示例 1:

输入:s = "()"
输出:true

示例 2:

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

示例 3:

输入:s = "(]"
输出:false

示例 4:

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

示例 5:

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

提示:

  • 1 < = s . l e n g t h < = 104 1 <= s.length <= 104 1<=s.length<=104
  • s 仅由括号 ()[]{} 组成

接下来看一下解题思路:

思路:栈:

    遍历给定的字符串 s s s。当遇到一个左括号时,期望在后续的遍历中,有一个相同类型的右括号将其闭合,因此我们可以将这个左括号放入栈顶;
    当我们遇到一个右括号时,我们需要将一个相同类型的左括号闭合;
    此时,我们可以取出栈顶的左括号并判断它们是否是相同类型的括号。如果不是相同的类型,或者栈中并没有左括号,那么字符串 s s s 无效,返回 False \text{False} False
    在遍历结束后,如果栈中没有左括号,说明我们将字符串 s s s 中的所有左括号闭合,返回 True \text{True} True,否则返回 False \text{False} False
    还可以做一些以下优化:

  • 使用哈希表存储每一种括号。哈希表的键为右括号,值为相同类型的左括号;
  • 有效字符串的长度一定为偶数,因此如果字符串的长度为奇数,我们可以直接返回 False \text{False} False
public static boolean isValid(String s) {
    if (s == null || (s.length() & 1) == 1) {
        return false;
    }
    Map<Character, Character> map = new HashMap<>();
    map.put(')', '(');
    map.put(']', '[');
    map.put('}', '{');

    Stack<Character> stack = new Stack<>();
    for (int i = 0; i < s.length(); ++i) {
        char c = s.charAt(i);
        if (map.containsKey(c)) {
            if (stack.isEmpty() || !stack.peek().equals(map.get(c))) {
                return false;
            }
            stack.pop();
        } else {
            stack.push(c);
        }
    }
    return stack.isEmpty();
}
总结

    时间复杂度: O ( n ) O(n) O(n),其中 n n n 是字符串 s s s 的长度;
    空间复杂度: O ( n + ∣ Σ ∣ ) O(n + |\Sigma|) O(n+Σ),其中 Σ \Sigma Σ 表示字符集,本题中字符串只包含 6 6 6 种括号, ∣ Σ ∣ = 6 |\Sigma| = 6 Σ=6。栈中的字符数量为 O ( n ) O(n) O(n),而哈希表使用的空间为 O ( ∣ Σ ∣ ) O(|\Sigma|) O(Σ),相加即可得到总空间复杂度;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值