使用Python实现一个栈判断括号是否平衡

作者:soong 时间:2022-01-04 02:20:29 

栈(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,栈,括号,平衡
0
投稿

猜你喜欢

  • python中关于xmltodict的使用

    2022-11-04 03:03:46
  • Python图像处理之图像量化处理详解

    2023-06-09 15:07:30
  • 一篇文章带你入门SQL编程

    2024-01-12 13:05:22
  • Python Django路径配置实现过程解析

    2023-11-13 20:50:02
  • ASP编程如何执行存储过程?

    2010-03-17 20:56:00
  • sqlserver中去除字符串中连续的分隔符的sql语句

    2024-01-24 02:45:51
  • JavaScript forEach()遍历函数使用及介绍

    2024-05-11 09:07:07
  • python实现彩色图转换成灰度图

    2022-03-11 02:41:30
  • 浅谈keras中loss与val_loss的关系

    2021-12-12 08:41:22
  • asp统计在线人数是实时的吗?

    2010-07-14 21:07:00
  • Python实现的矩阵类实例

    2023-08-13 07:52:09
  • 一个超级简单的python web程序

    2021-11-19 18:05:06
  • selenium WebDriverWait类等待机制的实现

    2022-12-18 13:07:21
  • CSS框架的利与弊

    2007-12-06 12:59:00
  • PHP微信开发之查询微信精选文章

    2023-11-14 12:45:54
  • 在SQL Server中编写通用数据访问方法

    2009-01-20 11:35:00
  • opencv-python基本图像处理详解

    2021-07-07 04:37:02
  • Python10行代码实现模拟百度搜索的示例

    2022-07-19 17:10:57
  • 关于vue.js中实现方法内某些代码延时执行

    2024-05-21 10:30:46
  • javaweb中mysql数据库连接步骤方法及其实例

    2024-01-29 08:06:45
  • asp之家 网络编程 m.aspxhome.com