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


Posted in Python onAugust 23, 2018

栈(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实现一个栈判断括号是否平衡,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Python 相关文章推荐
python中threading超线程用法实例分析
May 16 Python
Python3搜索及替换文件中文本的方法
May 22 Python
Python实现批量读取图片并存入mongodb数据库的方法示例
Apr 02 Python
python list是否包含另一个list所有元素的实例
May 04 Python
python 匹配url中是否存在IP地址的方法
Jun 04 Python
pandas进行数据的交集与并集方式的数据合并方法
Jun 27 Python
APIStar:一个专为Python3设计的API框架
Sep 26 Python
Python3日期与时间戳转换的几种方法详解
Jun 04 Python
python开发之anaconda以及win7下安装gensim的方法
Jul 05 Python
树莓派安装OpenCV3完整过程的实现
Oct 10 Python
Python爬虫获取页面所有URL链接过程详解
Jun 04 Python
OpenCV+python实现实时目标检测功能
Jun 24 Python
Python wxpython模块响应鼠标拖动事件操作示例
Aug 23 #Python
示例详解Python3 or Python2 两者之间的差异
Aug 23 #Python
Django 限制用户访问频率的中间件的实现
Aug 23 #Python
浅谈Django的缓存机制
Aug 23 #Python
如何在python字符串中输入纯粹的{}
Aug 22 #Python
关于python列表增加元素的三种操作方法
Aug 22 #Python
Python Learning 列表的更多操作及示例代码
Aug 22 #Python
You might like
通过PHP修改Linux或Unix口令的方法分享
2012/01/30 PHP
php显示时间常用方法小结
2015/06/05 PHP
关于PHP通用返回值设置方法
2017/03/31 PHP
支持汉转拼和拼音分词的PHP中文工具类ChineseUtil
2018/02/23 PHP
yii2的restful api路由实例详解
2019/05/14 PHP
解决iframe的frameborder在chrome/ff/ie下的差异
2010/08/12 Javascript
如何使用Javascript正则表达式来格式化XML内容
2013/07/04 Javascript
JS中三目运算符和if else的区别分析与示例
2014/11/21 Javascript
bootstrap datetimepicker2.3.11时间插件使用
2016/11/19 Javascript
JavaScript中三个等号和两个等号你了解多少
2017/07/04 Javascript
你应该知道的几类npm依赖包管理详解
2017/10/06 Javascript
Scala解析Json字符串的实例详解
2017/10/11 Javascript
jQuery Dom元素操作技巧
2018/02/04 jQuery
js/jQuery实现全选效果
2019/06/17 jQuery
使用JQuery自动完成插件Auto Complete详解
2019/06/18 jQuery
python装饰器-限制函数调用次数的方法(10s调用一次)
2018/04/21 Python
Python文本统计功能之西游记用字统计操作示例
2018/05/07 Python
Python3实现的简单三级菜单功能示例
2019/03/12 Python
python里 super类的工作原理详解
2019/06/19 Python
opencv 查找连通区域 最大面积实例
2020/06/04 Python
html5中为audio标签增加停止按钮动作实现方法
2013/01/04 HTML / CSS
html2canvas截图空白问题的解决
2020/03/24 HTML / CSS
天猫精选:上天猫,就够了
2016/09/21 全球购物
福克斯租车:Fox Rent A Car
2017/04/13 全球购物
英国PC组件和在线电脑商店:SCAN
2019/04/18 全球购物
仓库主管的岗位职责
2013/12/04 职场文书
入党积极分子思想汇报范文
2014/01/05 职场文书
自我评价格式
2014/01/06 职场文书
2014年大学生党课心得体会范文
2014/03/29 职场文书
党员干部观看《周恩来四个昼夜》思想汇报
2014/09/10 职场文书
公司法定代表人授权委托书
2014/09/29 职场文书
副校长个人对照检查材料思想汇报
2014/10/04 职场文书
财务会计实训报告
2014/11/05 职场文书
2015年学生会个人工作总结
2015/04/09 职场文书
python 实现图与图之间的间距调整subplots_adjust
2021/05/21 Python
Docker 镜像介绍以及commit相关操作
2022/04/13 Servers