【手绘算法】力扣 20 有效的括号(Valid Parentheses)

简介: Hi,大家好,我是Tom。一个美术生转到Java开发的程序员。今天给大家分享的是力扣题第20题,有效的括号。在解题过程中,也会手写一些伪代码。当然,如果想要完整的源码的话,可以到我的个人主页简介中获取。这道题呢比较简单,但是曾经成为B站的算法面试题,而且通过率只有44.5%。

Hi,大家好,我是Tom。一个美术生转到Java开发的程序员。今天给大家分享的是力扣题第20题,有效的括号。在解题过程中,也会手写一些伪代码。当然,如果想要完整的源码的话,可以到我的个人主页简介中获取。


这道题呢比较简单,但是曾经成为B站的算法面试题,而且通过率只有44.5%。

3ef0cebd1dc0495aa7183b8976d90999.png

1、题干分析

首先,我们还是来分析一下这道题的题干。

604a69cb9e81421ea6bcd972629242cb.png

它说,给定你一个只包括圆括号、花括号或者方括号的这么一个字符串,让你判断这个字符串是否有效。那这个字符串有效需要满足什么条件呢?

第一个条件是:左括号必须要有相同类型的右括号闭合。什么意思呢?就是它必须是一个有效的括号,比如说这样 ( )是一个有效的括号,那这样 ) ( 就不是一个有效的括号,当然,这样 ( ] 也不是一个有效的括号。

第二个条件是:左括号必须以正确的顺序闭合,那也就是跟上面描述的意思相同。

第三个条件是:说每个右括号都应该有一个相同类型的左括号对应。跟上面的意思也一样。

官方呢,也给了几个示例,我们来看一下:

9e3a501149c04005ba2ab16578b20bc4.png

输入左圆括号和右圆括号,输出结果为 true ,那么输入 左圆括号 和 右方括号,输出结果为 false。

对于这道题呢,它是为压栈这种方法而设计的。所以,我今天这道题呢,我给大家只讲一种解法,也就是压栈法求解。

4110490442514c93a0403094cd505e64.png

2、压栈法求解

接下来,老规矩,我们先来看用压栈法求解的解题思路。假设我们输入这样一个字符串(( )) [ ] ,一对圆括号中包含一对圆括号,然后外加一对方括号,我们一眼看上去显然是一对有效的括号。但是我们人能够一眼识别出来是有效的,不代表程序一眼就能看出来。所以,我们得有一个算法告诉我们的程序,如何来判断括号是有效的。

在这里,我们可以准备一个栈来做辅助。首先,我们需要从头到尾遍历一次这个字符串中的字符。在遍历的过程中,我们只要发现它是左边的括号(不管它是圆括号、花括号还是方括号,只要是左边的括号)就把它push到栈里来,这叫压栈。

比如说,我们往下遍历第一个是左圆括号,把它push到栈里来,第二个还是左圆括号,继续把它push到栈里面来。

再往下移发现是右圆括号,那这个时候我们应该怎么办呢?我们回顾一下,栈有什么特点?先入后出的特点,那我们来看,第一个进来的是左圆括号,压在栈底。第二个进来的也是左圆括号,目前压在栈顶。那如果我现在pop这个栈的话,第一个出来的应该最后push进来的值。

所以,我们遇到右括号,就把栈顶的值pop出来,那这个时候,我们发现右圆括号和栈顶的左圆括号是能够匹配的。于是,我们的遍历就可以接着往下走,继续拿到的值为右圆括号,这个时候我要继续pop这个栈,此时,取出的值为左圆括号,正好又能和右圆括号匹配。

于是,我们的遍历就继续往下走,继续拿到的值为左方括号,此时,我们就压栈。而这个时候,栈里面的全部已经pop完了,所以,左方括号这个时候又压到了栈底。

然后,继续放下遍历。我们又得到了一个右括号。遇到右括号要pop这个栈,此时,取出的值为左方括号,正好能跟右方括号匹配上。

3d80e74075a543ba9235eeef58b4d76d.png

前面的每一步遍历都成功匹配了,直到遍历完成。那么最后,我们只需要判断这个栈是不是为空,如果为空,说明所有括号都是有效匹配,返回为true。

比如说,我们是输入是这个字符串后面再加一个花括号。那这个时候遍历完成的时候,发现栈中值不为空,栈的花括号没有可以跟它匹配值了,这个时候就应该返回false。

当然,如果遇到右括号,从栈中pop出来的值不能和右括号匹配的,就直接终止遍历返回false,因为,再往下遍历已经没有意义了。

所以说,有效的括号它们都是情侣,要成双成对地出现,不会有多余的单身狗,也不会有不同类型括号谈恋爱,比如小倩和宁采臣,人妖相恋也不符合人伦。

下面来看一下压栈法解法的伪代码。

393a1818f22f405887e053dfd58659c5.png

以上就是我关于有效的括号这道题的解题思路分享。这道题的算法很简单,主要是考核栈这种数据结构,当遇到左括号的时候,就做压栈操作,遇到右括号的时候,就将栈顶的元素做出栈操作,并且判断是否匹配。


我是被编程耽误的文艺Tom,如果我的分享对你有帮助,请动动手指一键三连分享给更多的人。关注我,面试不再难!


附:完整源码地址:

GitHub

https://github.com/gupaoedu-tom/exercise-leetcode/blob/main/src/main/java/com/gupaoedu/exercise/leetcode/ValidParentheses.java

GitEE

https://gitee.com/gupaoedu-tom/exercise-leetcode/blob/main/src/main/java/com/gupaoedu/exercise/leetcode/ValidParentheses.java

相关文章
|
19天前
|
算法 容器
【算法】——双指针算法合集(力扣)
移动零,复写零,快乐数,盛最多水的容器,有效三角形的个数,和为s的两个数(查找总价格为目标值的两个商品 ),三数之和,四数之和
|
2月前
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
|
3月前
|
算法
【链表】算法题(二) ----- 力扣/牛客
【链表】算法题(二) ----- 力扣/牛客
|
3月前
|
算法 C++
Leetcode第二十二题(括号生成)
这篇文章讨论了如何使用递归算法解决LeetCode第22题“括号生成”的问题,提供了两种C++的实现方法,目的是生成所有有效的括号组合。
27 0
Leetcode第二十二题(括号生成)
|
3月前
|
算法 数据挖掘
【栈和队列】算法题 ---- 力扣(二)
【栈和队列】算法题 ---- 力扣
|
3月前
|
存储 算法
【栈和队列】算法题 ---- 力扣(一)
【栈和队列】算法题 ---- 力扣
|
3月前
|
存储 C++ 容器
Leetcode第二十题(有效的括号)
这篇文章介绍了如何使用栈来解决LeetCode第20题“有效的括号”问题,提供了两种方法:数组栈和容器栈,以及相应的C++代码实现。
24 0
|
3月前
|
算法
【链表】算法题(一) ----- 力扣 / 牛客
【链表】算法题(一) ----- 力扣 / 牛客
|
4月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
5月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
136 2