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

括号匹配——(栈实现)

题目链接

有效的括号icon-default.png?t=O83Ahttps://leetcode.cn/problems/valid-parentheses/description/

题目要求

样例

解题代码

import java.util.*;
class Solution {public boolean isValid(String str) {Stack<Character> stack=new Stack<>();for(int i=0;i<str.length();i++){char ch=str.charAt(i);if(ch=='('||ch=='{'||ch=='['){stack.push(ch);}else{if(stack.empty()){return false;}if(ch=='}'&&stack.peek()=='{'||ch==']'&&stack.peek()=='['||ch==')'&&stack.peek()=='('){stack.pop();}else{return false;}}}if(!stack.empty()){return false;}return true;}
}

思路

此问题主要分以下几种情况:

1、我们先初始化一个栈,对已有的字符串进行逐个遍历;

2、进行判断是否为左括号,若为左括号,则存入栈中;若为右括号:此时先判断栈是否为空:(1)为空的情况下,说明右括号多,返回 false

(2)不为空,则判断是否匹配

        (2.1)匹配的话,将栈中的左括号取出

        (2.2)不匹配,说明括号顺序不匹配,如上图2;返回 false;

3、最后,for 循环遍历完,检查栈是否还有元素(左括号多),若不为空,返回 false;最后返回           true;表示全部匹配;

个人总结

本篇陌生知识点为:

1、导入包,快速创建栈,利用泛型规定栈内数据类型;

2、字符串转化为字符数组,并遍历;

import java.util.*;public boolean isValid(String str) {Stack<Character> stack=new Stack<>();for(int i=0;i<str.length();i++){char ch=str.charAt(i);}}

http://www.mrgr.cn/news/44532.html

相关文章:

  • Java 中的 File 类及 InputStream 和 OutputStream 的用法总结
  • 医院综合服务系统小程序的设计
  • 简单理解动态规划
  • 基于ssm 和uniapp 开发的微信小程序的学生选课系统设计与实现
  • 代码随想录 103. 水流问题
  • 开发自定义starter
  • 【电力系统】基于MATLAB的储能辅助电力系统调峰的容量需求研究
  • Flutter平台嵌入器
  • 图解Linux文件属性与目录配置
  • Ubuntu查看磁盘空间使用情况
  • 中国书法-孙溟㠭浅析碑帖《九成宫醴泉铭》
  • 分层解耦-01.三层架构
  • Stable Diffusion绘画 | 插件-Deforum:商业LOGO广告视频
  • 图像转3D视差视频:DepthFlow、kling
  • 如何搭建基于大模型的智能知识库
  • 设计模式~~~
  • 基于Netty框架的云快充协议+桩直连协议+充电桩系统
  • 【SQL】深入理解SQL:从基础概念到常用命令
  • 【机器学习-无监督学习】概率图模型
  • 油卡回收源码含教程