使用Python实现一个栈判断括号是否平衡
作者:soong 发布时间:2022-01-04 02:20:29
标签:python,栈,括号,平衡
栈(Stack)在计算机领域是一个被广泛应用的集合,栈是线性集合,访问都严格地限制在一段,叫做顶(top)。 举个例子,栈就想一摞洗干净的盘子,你每次取一个新盘子,都是放在这一摞盘子的最上头,当你往里面添加盘子的时候,也是放在最上面,处在底部的盘子,你可能永远也用不到。 栈的最常见操作,有如下两个:
push(a) # 压入,将a压入的栈中
pop() # 弹出,将栈的最后一个元素弹出
可是使用Python的列表数据结构,来模拟栈的操作,使用 append 来模拟 push ,使用列表的 pop 来模拟栈的 pop ,但是这样做有一个弊端,那就是列表原本自带的操作方法同样能够使用,可能会造成混乱。
栈的实现 下面就通过借助Python的列表,来自定义一个栈类:
class Stack(object):
"""使用数组实现一个栈"""
def __init__(self):
self.data = []
def push(self, num):
"""压栈操作"""
self.data.append(num)
def pop(self):
"""返回从栈中弹出的元素, 当栈为空的时候, 抛出IndexError"""
return self.data.pop()
def peek(self):
"""查看当前栈顶的元素, 当栈为空的时候, 抛出IndexError"""
return self.data[-1]
def __len__(self):
"""返回栈的长度, 调用len(obj)时会自动调用obj对象的__len__方法"""
return len(self.data)
def isEmpty(self):
"""判断栈是否为空"""
return True if len(self.data)==0 else False
def clear(self):
"""清空栈"""
self.data = []
def __repr__(self):
"""当前对象的表现形式, 在终点直接键入对象时会调用"""
return 'Stack_' + str(self.data)
def __str__(self):
"""当前对象的字符串表示, 使用print(obj)时会调用"""
return 'Stack_' + str(self.data)
以上代码实现了一个简单的基于列表的栈。
栈的应用 栈应用的一个很典型的例子,就是检查括号是否匹配。 例如: 每一个开始的 [ 后面,都应该跟着一个位置正确的 ] ,并且每一个 ( 后面,也应该跟着一个位置正确的结束的 ) .
(...)...(...)
(...)...(...
)...((...)
def isBalance(text):
"""栈的应用,检查括号是否平衡"""
result_stack = Stack()
for i in text:
if i in ['{', '[', '(']:
result_stack.push(i)
elif i in ['}', ']', ')']:
# 遇到结束括号的情况
if result_stack.isEmpty():
# 如果当前栈为空, 不匹配,返回False
return False
chFromStack = result_stack.pop()
if not ((chFromStack == '{' and i == '}' )
or (chFromStack == '[' and i == ']')
or (chFromStack == '(' and i == ')')):
# 如果不满足匹配条件, 则返回False
return False
# 遍历结束后, 如果结果栈为空, 则代表括号匹配, 栈不为空, 括号不匹配
return result_stack.isEmpty()
补充:Python中的栈
在python中,个人理解为栈可以用列表来代替
服从FILO:First In Last Out
其中入栈为(利用append函数)
stack = []
stack.append(<item>)
出栈为(利用pop函数)
stack.pop(-1) #stack.pop()也可
服从FIFO:First In First Out
入栈为:
stack = []
stack.append(<item>)
出栈为:
stack.pop(0)
总结
以上所述是小编给大家介绍的使用Python实现一个栈判断括号是否平衡网站的支持!
来源:https://juejin.im/post/5b7c01c9e51d45388325208a


猜你喜欢
- 最近在用python连接sqlserver读取数据库,读取数据时候在本机电脑正常,但是把程序部署到服务器运行时一直报错“未发现数据源名称并且
- 本文介绍了vscode 远程调试python的方法,分享给大家,具有如下:实验环境远程服务器:京东云,1核2G,centos7.3 64bi
- 利用SocketServer模块来实现网络客户端与服务器并发连接非阻塞通信。首先,先了解下SocketServer模块中可供使用的类:Bas
- 一、MHA介绍(一)、什么是MHAMHA(MasterHigh Availability)是一套优秀的MySQL高可用环境下故障切换和主从复
- 描述tan() 返回x弧度的正弦值。语法以下是 tan() 方法的语法:import mathmath.tan(x)注意:tan()是不能直
- 前言在这个教程中,我们将会通过几个例子,了解和学习VueJs的过滤器。阅读这这篇文中的前提是你对Vue已经有了基本的语法基础。Vue.Js中
- 那你也许会问及,怎样获取当前系统日期的最大时间值,如yyyy-MM-dd 23:59:59.997。 我们可以使用DATEADD函数,来实现
- 我就废话不多说了,直接上代码吧!#全0和全1矩阵v1 = tf.Variable(tf.zeros([3,3,3]), name="
- Python 3最重要的新特性大概要算是对文本和二进制数据作了更为清晰的区分。文本总是Unicode,由str类型表示,二进制数据则由byt
- 打开网页,然后将javascript:document.body.contentEditable='true';
- 在MySQL中,对于索引的使用并是一直都采用正确的决定。简单表的示例:CREATE TABLE `r2` (ID` int(11) DEFA
- 对于比较长的数字组成的字符串,我们一般会用逗号(,)隔开来格式化数字,从右往左每三个数字用一个逗号分组隔开。为什么要用逗号隔开数字呢?因为当
- 在服务器上,通常为了快速登录数据库,我们会使用mysql -hhost -uusername -ppassword db的方式登录数据库,如
- 以前看过几个JS代码格式的,自己也来写了一个,呵呵,优点是可以处理超长的 JS 而不会死机.........IE Only运行代码框<
- Python 发送邮件我以前在通过Python实现自动化邮件功能的时候是这样的:import smtplibfrom email.mime.
- 代码如下:arr = array(12,52,14,43,24,58,15,64,24,57,17,56,45)&nbs
- array和asarray都可以将结构数据转化为ndarray,但是主要区别就是当数据源是ndarray时,array仍然会copy出一个副
- 网上大部分都是上传文件,于是个人参照网上一些博客的内容,写了一个把windows上目录上传到远程linux的一个小程序。下面是代码:clas
- 1. 什么是网络爬虫简单来说,就是构建一个程序,以自动化的方式从网络上下载、解析和组织数据。就像我们浏览网页的时候,对于我们感兴趣的内容我们
- 八皇后问题描述问题: 国际象棋棋盘是8 * 8的方格,每个方格里放一个棋子。皇后这种棋子可以攻击同一行或者同一列或者斜线(左上左下右上右下四