使用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的迭代器、生成器以及相关的itertools包
Apr 02 Python
Python中使用strip()方法删除字符串中空格的教程
May 20 Python
Python实现屏幕截图的两种方式
Feb 05 Python
Python(TensorFlow框架)实现手写数字识别系统的方法
May 29 Python
python绘制圆柱体的方法
Jul 02 Python
Python实现繁体中文与简体中文相互转换的方法示例
Dec 18 Python
正确理解Python中if __name__ == '__main__'
Jan 24 Python
Django 配置多站点多域名的实现步骤
May 17 Python
基于python cut和qcut的用法及区别详解
Nov 22 Python
python基于exchange函数发送邮件过程详解
Nov 06 Python
Django celery异步任务实现代码示例
Nov 26 Python
Python+Tkinter打造签名设计工具
Apr 01 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
smarty实例教程
2006/11/19 PHP
smarty模板中使用get、post、request、cookies、session变量的方法
2014/04/24 PHP
微信公众平台天气预报功能开发
2014/07/06 PHP
Codeigniter的一些优秀特性总结
2015/01/21 PHP
smarty内置函数capture用法分析
2015/01/22 PHP
非常好的js代码
2006/06/27 Javascript
JS遮罩层效果 兼容ie firefox jQuery遮罩层
2010/07/26 Javascript
从盛大通行证上摘下来的身份证验证js代码
2011/01/11 Javascript
JQuery入门——事件切换之hover()方法应用介绍
2013/02/05 Javascript
Javascript自定义排序 node运行 实例
2013/06/05 Javascript
JavaScript实现从数组中选出和等于固定值的n个数
2014/09/03 Javascript
vue.js父组件使用外部对象的方法示例
2017/04/25 Javascript
Vue引用第三方datepicker插件无法监听datepicker输入框的值的解决
2018/01/27 Javascript
vue1.0和vue2.0的watch监听事件写法详解
2018/09/11 Javascript
详解如何webpack使用DllPlugin
2018/09/30 Javascript
举例讲解Python面向对象编程中类的继承
2016/06/17 Python
windows环境下tensorflow安装过程详解
2018/03/30 Python
python2.7和NLTK安装详细教程
2018/09/19 Python
python中文分词库jieba使用方法详解
2020/02/11 Python
python常用运维脚本实例小结
2020/02/14 Python
Python爬虫实现百度翻译功能过程详解
2020/05/29 Python
Python爬虫之爬取淘女郎照片示例详解
2020/07/28 Python
通过实例解析Python文件操作实现步骤
2020/09/21 Python
pycharm 配置svn的图文教程(手把手教你)
2021/01/15 Python
美国女孩洋娃娃店:American Girl
2017/10/24 全球购物
DERMAdoctor官网:美国著名皮肤护理品牌
2019/07/06 全球购物
竞争上岗演讲稿
2014/01/05 职场文书
学习2014年全国两会心得体会
2014/03/12 职场文书
幼儿园的门卫岗位职责
2014/04/10 职场文书
小学亲子活动总结
2014/07/01 职场文书
大学生万能检讨书范例
2014/10/04 职场文书
关于运动会的广播稿50字
2014/10/17 职场文书
酒店前台辞职书
2015/02/26 职场文书
《学会看病》教学反思
2016/02/17 职场文书
用position:sticky完美解决小程序吸顶问题的实现方法
2021/04/24 HTML / CSS
使用python将HTML转换为PDF pdfkit包(wkhtmltopdf) 的使用方法
2022/04/21 Python