OJ题解:有效的括号

题目

题目链接

题目链接

题目描述

题目解析

该题可以利用栈这个数据结构来解决,因为最后一个左括号是要和第一个右括号匹配的,倒数第二个左括号是要和第二个右括号匹配的,以此类推...可以看出左括号有后进先出,先进后出的特点,符合栈的特点。

可以用一个for循环从左到右获取字符串的每一个字符,每获取一个字符,就检查是左括号还是右括号,如果是左括号就入栈,如果是右括号,就检查他和左括号匹不匹配。因此,有两种情况可以直接判定为无效的括号。

第一种就是已经检测到右括号了,但是还没检测到左括号,即没有左括号入栈;或者是左括号已经被右括号匹配完了,但是还有右括号,这两种栈为空的情况,就可以直接判定为无效的括号,返回false。比如:)()(),检测到第一个右括号)了,但是前面还没有左括号。还有(())))左括号已经被匹配完了,依旧剩有右括号,也可以直接判定为无效的括号,返回false。

第二种情况就是右括号和左括号不匹配,也可以直接判定为无效的括号,返回false。比如:{[{)]},第一个右括号为)和倒数第一个左括号{不匹配。

再来说说匹配的情况,右括号要匹配左括号时,因为目前你还不知道匹不匹配,不能直接pop,要先peek一下,peek后匹配的话,才能pop。

最后右括号都匹配完左括号了,还得检查一边左括号有没有全被匹配完,如果没有的话就是无效的括号。比如:(({[{[()]}{}()[],当所有右括号都匹配完左括号,还剩下四个左括号(({[,这种情况就是无效的括号。

Java代码实现

java 复制代码
class Solution {
    public boolean isValid(String s) {
        Stack<Character> stack = new Stack<>();
        for(int i = 0 ; i < s.length(); i++) {
            char ch = s.charAt(i);
            //检测到左括号入栈
            if(ch == '(' || ch == '{' || ch == '[') {
                stack.push(ch);
            } else { //检测到右括号
                if(stack.empty()) { //如果没有左括号,或左括号已经被匹配完,返回false
                    return false;
                } 
                char top = stack.peek();
                //现在top是左括号,ch是右括号 
                if((top == '(' && ch == ')') || (top == '{' && ch == '}') || (top == '[' && ch == ']')) {
                    stack.pop();
                } else {
                    return false;
                }
            }
        }
        if(!stack.empty()) { //最后所有右括号都匹配上了左括号,还得检查一下左括号有没有被匹配完
            return false;
        } 
        return true;
    }
}
相关推荐
通往曙光的路上14 小时前
SpringSecurity
java
_oP_i14 小时前
Pinpoint 是一套为分布式 Java/PHP 系统做调用链追踪 + 性能分析的方案
java
架构师专栏14 小时前
Spring Boot 4 整合46篇教程,Spring Boot 4 企业级项目开发完整实践指南
java·spring boot·后端
专注VB编程开发20年14 小时前
Activex dll创建调用-Python,Node.js, JAVA主流编程语言操作COM对象
java·开发语言·python·node.js·activex dll
代码or搬砖15 小时前
公共字段抽取自动填充
android·java·数据库
老华带你飞15 小时前
校园快递|基于Java校园快递管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
AndreasEmil16 小时前
JavaSE - 继承
java·开发语言·ide·vscode·intellij-idea·idea
后端小张16 小时前
【JAVA 进阶】SpringBoot自动配置机制:从原理到实践的深度解析
java·spring boot·后端·spring·spring cloud·自动配置·注解
毕设源码-赖学姐1 天前
【开题答辩全过程】以 高校评教评学系统的设计与实现为例,包含答辩的问题和答案
java·eclipse