每日一题:Leetcode20 有效的括号
admin
2024-05-06 08:22:11
0

文章目录

系列:栈专练
语言:java
题目来源:leetcode20 有效的括号
难度:简单
考点:栈的理解 & 应用


思路和参考答案

  • 文章目录
  • 题目描述
  • 一、思路
  • 二、参考代码


题目描述

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

有效字符串需满足:

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

示例 1:

输入:s = “()”
输出:true

示例 2:

输入:s = “()[]{}”
输出:true

示例3:

输入:s = “(]”
输出:false

提示:

1 <= s.length <= 10^4
s 仅由括号 ‘()[]{}’ 组成

一、思路

对称匹配问题,非常适合使用栈来解决;
方法选择:通常不使用Stack类来定义栈,使用性能更优的双端队列接口Deque来定义栈,实现类ArrayDeque/LinkedList来进行初始化

Deque deque = new ArrayDeque<>();
Deque deque = new LinkedList<>();

有关栈的一些方法:

pop() : 出栈 删除栈顶元素
push(): 入栈 元素压入栈顶
peek(): 查看栈顶元素
isEmpty(): 判断栈是否为空

本文我们使用实现LinkedList类解答;
解题思路:看到题目后很容易想到使用栈来解决问题,但是我们该怎么去着手呢?怎样去通过栈操作来实现匹配呢?
首先是字符串的长度,如果字符串为奇数,则返回false;另一种情况当然是符合题意的偶数段字符串长度,然后分为三种情况,一种是左边符号多( ‘(((}’ ),第二种是右边符号多( ‘()))’ ),第三种是一样多但是括号不匹配( "((]] ).
我们这里通过一个for循环来进行遍历字符串,通过if语句来对三种情况以及其他情况进行判断,if条件判断
举一个例子:每当有一个左括号时,栈里就push()入一个对应的右括号,一次遍历,此时栈内元素为( “)))”)当s.charAt(i) =='}‘时,栈内没对应元素,返回false ;如果是( ‘((()’ ), 当s.charAt(i) ==’)'时,栈内有元素,弹出栈顶元素,栈内元素为( ‘))’) ,此时字符串里没有对应的右括号来匹配,所以返回fasle;如果是 ( ‘()))’ ),此时栈内元素为 ( ‘)’ ),当for循环遍历匹配了一个右括号时,弹出后,栈内没有元素,栈为空,此时还有两个)没有被匹配,所以此时返回false;同时如果当s.charAt(i) != deque.peek() 时,也是返回false,参考代码更容易来理解

二、参考代码

双指针–滑动窗口:

class Solution {public boolean isValid(String s) {
// 栈的使用:
//       使用Deque来定义栈 Deque代替使用Stack 性能更优
//       同时可以使用ArrayDeque和LinkedList
// 当字符串长度为奇数的时候,不满足题意,所以直接返回falseif(s.length() % 2 != 0){return false;}
// 使用Deque来定义栈 Deque deque = new LinkedList<>();char ch;
// 通过for循环一次对字符进行情况匹配for(int i =0;iif(s.charAt(i) == '('){deque.push(')');}else if(s.charAt(i) == '{'){deque.push('}');}else if(s.charAt(i) == '['){deque.push(']');// 当字符在匹配完,此时栈内为空了,则说明右括号多了,则返回false 同时还有右括号和栈顶元素不匹配,同样返回false}else if(deque.isEmpty() || s.charAt(i) != deque.peek()){return false;}else{// **这里的else的条件时  s.charAt(i) = deque.peek()情况**,因为已经判断过不相等的情况了 ,这里是三种右括号匹配时的情况判断,           deque.pop();}}// 如果都匹配,则栈内元素为空 返回true ,如果情况为:左括号多了 ,栈内元素不为空,此时返回false       return deque.isEmpty();}}

创作不易:感谢您的一键三连!希望对您有所帮助

相关内容

热门资讯

公募一季度“抱团”创业板大牛股... 本文来源:时代周报 作者:谢怡雯 兰烁近期,公募基金一季报陆续披露完毕,持仓情况随之出炉。据Wind...
普京:俄军正与“北约支持的侵略... 据央视新闻消息,俄罗斯总统普京9日在纪念卫国战争胜利81周年阅兵活动上说,参加特别军事行动的俄军正在...
王兴兴:具身智能是否迎来“Ch... 12月11日消息,宇树科技创始人兼首席执行官王兴兴表示,具身智能是否迎来“ChatGPT时刻”的关键...
2026元旦小长假热门城市酒店... 12月11日消息,2026年的元旦比2025年多放2天假,为文旅消费市场带来乘数级拉动效应。去哪儿旅...
LME铜价创下纪录新高,突破每... 12月11日消息,LME伦铜涨幅扩大,现涨2.04%,最新报11791.78美元/吨,创盘中历史新高...
甲骨文跌超16% 12月11日消息,甲骨文跌超16%,市值蒸发1020亿美元。(科股宝播报)
纳斯达克中国金龙指数跌超1%,... 12月11日消息,纳斯达克中国金龙指数跌超1%,嘉楠科技跌超6%,新氧跌超5%,BOSS直聘、1药网...
陕西西咸新区发展集团披露子公司... 5月8日,中国银行间市场交易商协会官网上发布了陕西西咸新区发展集团有限公司的《关于重大事项的公告》。...
追觅俞浩,正在疯狂作秀 追觅科... 出品丨花朵财经观察(FF-Finance)撰文丨华见最近科技圈最大的乐子,非追觅CEO俞浩莫属。这位...
多地号召,公职人员带头缴纳物业... 近期,多地发布了号召公职人员、党员干部带头缴纳物业费的倡议书,引发关注。其中,江西省九江共青城市、柴...