-
题目
java给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。 有效字符串需满足: 1、左括号必须用相同类型的右括号闭合。 2、左括号必须以正确的顺序闭合。 3、每个右括号都有一个对应的相同类型的左括号。 -
示例
java示例 1: 输入:s = "()" 输出:true 示例 2: 输入:s = "()[]{}" 输出:true 示例 3: 输入:s = "(]" 输出:false -
解题思路
- 栈。核心思路是判断括号是否匹配,遍历串,如果是左括号,就先放着等待后面出现的右括号和其匹配。如果是左括号,则取匹配之前暂时存放的左括号,看是否匹配。该逻辑和栈的逻辑一直。可以使用栈进行存储遍历中的左括号,栈是先进先出,先放进的后匹配,后放进的先匹配,保证了匹配右括号的顺序。
-
代码(Java)
java// 方法一 import java.util.Stack; class Solution { public boolean isValid(String s) { if (s == null || s.length() == 0) { return true; } if (s.length() % 2 == 1) { return false; } Stack<Character> stack = new Stack<>(); for (int i = 0; i < s.length(); i++) { char c = s.charAt(i); if (c == '(' || c == '[' || c == '{') { stack.push(c); } else { if (stack.isEmpty()) { return false; } char cpop = stack.pop(); if (!(cpop == '(' && c == ')' || cpop == '[' && c == ']' || cpop == '{' && c == '}')) { return false; } } } return stack.isEmpty() ? true : false; } }
LeetCode20 有效的括号
biglxl2024-02-26 20:43
相关推荐
Mr_Xuhhh2 分钟前
深入理解单链表的递归反转:从原理到实现智者知已应修善业7 分钟前
【51单片机数码管+蜂鸣器的使用】2023-6-14迷途之人不知返14 分钟前
算法类型:双指针类型吴可可12318 分钟前
三点绘圆弧的几何实现kyle~22 分钟前
导航---LIO(激光雷达-惯性里程计)算法AGI前沿30 分钟前
# 反内卷,回基础:Nano-Memory用极简检索与剪枝,解决大模型长对话遗忘无限进步_37 分钟前
【C++】私有虚函数与多态:访问权限不影响动态绑定努力努力再努力wz38 分钟前
【MySQL入门系列】:不只是建表:MySQL 表约束与 DDL 执行机制全解析君鼎41 分钟前
C++20 新特性全面总结枫叶机关录1 小时前
算法笔记:K-means、K-means++与K-Medoids聚类算法--详解、案例分析