LeetCode:20. 有效的括号

简介

题目链接:https://leetcode.cn/problems/valid-parentheses/description/

解决方式:字符串 + 栈 / 栈、映射

实现思路:

迭代字符,遇到左括号则放入栈中否则根据当前的右括号去栈中匹配。栈顶元素若不是右括号对应的左括号就证明包含无效括号。迭代结束后栈中应无数据,有则证明左括号多了。

java 复制代码
class Solution {
    public boolean isValid(String s) {
        int n = s.length();
        // 转换为字符数组
        char[] ch = s.toCharArray();
        // 栈
        Stack<Character> stack = new Stack<>();
        // 循环
        for(int i = 0; i < n; i++){
            // 左括号加入栈
            if(ch[i] == '(' || ch[i] == '{' || ch[i] == '[') {
                stack.add(ch[i]);
            }else{
                // 右括号匹配
                if(stack.isEmpty()) {
                    return false;
                }
                if(ch[i] == ')' && stack.pop() != '(') {
                    return false;
                }else if(ch[i] == '}' && stack.pop() != '{') {
                    return false;
                }else if(ch[i] == ']' && stack.pop() != '[') {
                    return false;
                }
            }
        }
        // 循环结束栈中应无数据,若有则有无效括号
        return stack.size() > 0 ? false : true;
    }
}

栈、映射

实现思路:

这是另一种写法,将左右括号的匹配加入映射而非直接硬编码。这种写法时间复杂度较高。

java 复制代码
class Solution {
    public boolean isValid(String s) {
        // 边界处理
        if(s == "" || s.length() % 2 != 0){
            return false;
        }
        // 有效括号映射
        Map<Character, Character> pairs = new HashMap<>();
        pairs.put(')', '(');
        pairs.put(']', '[');
        pairs.put('}', '{');
        // 栈
        Deque<Character> stack = new ArrayDeque<>();
        // 循环,遇到左括号入栈,遇到右括号则匹配栈中的左括号
        for(int i = 0; i < s.length(); i++){
            char c = s.charAt(i);
            if(pairs.containsKey(c)){
                // 栈为空 或 栈顶不匹配 -> 无效
                if(stack.isEmpty() || stack.pop() != pairs.get(c)){
                    return false;
                }
            }else{
                // 左括号直接入栈
                stack.push(c);
            }

        }
        // 所有字符处理完后,栈应为空。不为空则有无效括号。
        return stack.isEmpty();
    }
}
相关推荐
计算机安禾1 小时前
【算法设计与分析】第40篇:空间数据结构:KD树与四叉树的查询分析
数据结构·算法
m沐沐1 小时前
【机器学习】信用卡欺诈检测实战:逻辑回归 + 过采样
人工智能·算法·机器学习·pycharm·逻辑回归
代码中介商2 小时前
图论入门:从基础到遍历算法
数据结构·算法·图论
csdn_aspnet2 小时前
Python 霍尔分区算法(Hoare‘s Partition Algorithm)
开发语言·python·算法
8Qi82 小时前
LeetCode 295:数据流的中位数(Median Finder)—— Java 题解 ✅
java·算法·leetcode·优先队列··中位数
Raink老师2 小时前
【AI面试临阵磨枪-89】Skill 幻觉、参数缺失、格式错误、业务异常如何处理?
面试·职场和发展
Trouvaille ~2 小时前
【Redis篇】Redis 事务:原子性与脚本执行机制
数据库·redis·后端·算法·junit·lua·原子性
飞天狗1112 小时前
2024第十五届蓝桥杯c/c++B组国赛题解
c语言·数据结构·c++·算法·蓝桥杯
rsuhbsrjms2 小时前
可视采耳仪器多少钱一台?可视耳勺哪个牌子好?口碑好的可视耳勺
网络·人工智能·算法