当前位置: 首页 > news >正文

Java括号匹配

目录

一、题目描述

二、题解


一、题目描述

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

有效字符串需满足:

  1. 左括号必须用相同类型的右括号闭合。
  2. 左括号必须以正确的顺序闭合。
  3. 每个右括号都有一个对应的相同类型的左括号。

示例:

输入:s = "()"

输出:true

输入:s = "(]"

输出:false

二、题解

思路分析:

我们可以使用来解决这个问题:

遍历字符串,如果是左括号,就将其入栈

如果是右括号,就将栈顶元素弹出,判断是否是与其匹配的左括号,

若栈中无元素可以弹出,则无能与该右括号匹配的左括号,返回false,

若不是与其匹配的左括号,返回false,

若是与其匹配的左括号,则继续遍历下一个字符。

当循环结束时,判断栈是否为空,

若栈不为空,则表明还有未匹配的左括号,返回false,

若栈为空,则表示所有的左括号都与相同类型的右括号匹配,返回true

代码实现:

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 {//右括号,出栈//无左括号能够匹配,返回falseif(stack.empty()){return false;}char ch2 = stack.pop();if((ch2 == '(' && ch == ')') || (ch2 == '[' && ch == ']') || (ch2 == '{' && ch == '}')){}else {return false;}}}return stack.empty();}
}

题目来自:

20. 有效的括号 - 力扣(LeetCode)

http://www.lryc.cn/news/177373.html

相关文章:

  • 自动化测试-友好的第三方库
  • 基于微信小程序的火锅店点餐订餐系统设计与实现(源码+lw+部署文档+讲解等)
  • 亿图脑图新版本支持思维导图一键生成PPT、音视频等格式,办公提效再升级
  • Arthas:Java调试利器使用
  • Nuxt 菜鸟入门学习笔记七:SEO 和 Meta 设置
  • 栈(Stack)和队列(Queue)
  • LeetCode 75 part 06 栈
  • 19.组合模式(Composite)
  • 应用在IPM接口隔离领域中的光电耦合器
  • rust引用
  • Android AMS——Activity Pause(八)
  • 【数据结构】冒泡排序,快速排序的学习知识总结
  • ubuntu终端 中文显示 改为 英文显示
  • ChatGPT Prompting开发实战(十二)
  • springboot整合eureka
  • 记录一个 GUI 库的对比测试结果
  • 解决 MyBatis-Plus 中增加修改时,对应时间的更新问题
  • 【力扣2057】值相等的最小索引
  • 计算机图像处理:图像轮廓
  • 解决java.io.FileNotFoundException: HADOOP_HOME and hadoop.home.dir are unset.的错误
  • 软件设计中常见的设计模式
  • 为什么我的remix没有injected web3
  • 第1章 数据结构绪论
  • 现代 GPU 容易受到新 GPU.zip 侧通道攻击
  • 8+单基因+细胞凋亡+WGCNA+单细胞+实验验证
  • BM4 合并两个排序的链表
  • 【lesson12】理解进程地址空间
  • 计算机里的神灵(SCIP)
  • 基于微信小程序的公交信息在线查询系统小程序设计与实现(源码+lw+部署文档+讲解等)
  • 【STM32】IAP升级01 bootloader实现以及APP配置(主要)