使用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来使用七牛云存储的方法详解
Aug 07 Python
在Python的Flask中使用WTForms表单框架的基础教程
Jun 07 Python
Python pymongo模块用法示例
Mar 31 Python
利用Python进行数据可视化常见的9种方法!超实用!
Jul 11 Python
[原创]Python入门教程4. 元组基本操作
Oct 31 Python
详解利用OpenCV提取图像中的矩形区域(PPT屏幕等)
Jul 01 Python
Django框架模型简单介绍与使用分析
Jul 18 Python
详解opencv中画圆circle函数和椭圆ellipse函数
Dec 27 Python
python随机模块random使用方法详解
Feb 14 Python
python爬虫构建代理ip池抓取数据库的示例代码
Sep 22 Python
python爬虫--selenium模块
Mar 31 Python
Keras多线程机制与flask多线程冲突的解决方案
May 28 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
计数器详细设计
2006/10/09 PHP
php ajax confirm 删除实例详解
2019/03/06 PHP
javascript定时变换图片实例代码
2013/03/17 Javascript
JS 去除Array中的null值示例代码
2013/11/20 Javascript
JavaScript/Js脚本处理html元素的自定义属性解析(亲测兼容Firefox与IE)
2013/11/25 Javascript
导入extjs、jquery 文件时$使用冲突问题解决方法
2014/01/14 Javascript
jquery遍历checkbox的注意事项说明
2014/02/21 Javascript
TypeScript 学习笔记之基本类型
2015/06/19 Javascript
基于JavaScript实现 网页切出 网站title变化代码
2016/04/03 Javascript
js仿iphone秒表功能 计算平均数
2017/01/11 Javascript
详谈Angular 2+ 的表单(一)之模板驱动型表单
2017/04/25 Javascript
nodeJS(express4.x)+vue(vue-cli)构建前后端分离实例(带跨域)
2017/07/05 NodeJs
node koa2实现上传图片并且同步上传到七牛云存储
2017/07/31 Javascript
浅谈react.js中实现tab吸顶效果的问题
2017/09/06 Javascript
Easy UI动态树点击文字实现展开关闭功能
2017/09/30 Javascript
Vue作用域插槽slot-scope实例代码
2018/09/05 Javascript
微信开发之企业付款到银行卡接口开发的示例代码
2018/09/18 Javascript
Bootstrap的aria-label和aria-labelledby属性实例详解
2018/11/02 Javascript
小程序开发中如何使用async-await并封装公共异步请求的方法
2019/01/20 Javascript
node.js中module模块的功能理解与用法实例分析
2020/02/14 Javascript
js实现拖拽与碰撞检测
2020/09/18 Javascript
[02:21]2018完美盛典章节片——初心
2018/12/17 DOTA
Python类的基础入门知识
2008/11/24 Python
Python查询Mysql时返回字典结构的代码
2012/06/18 Python
使用Python脚本在Linux下实现部分Bash Shell的教程
2015/04/17 Python
Python定时执行之Timer用法示例
2015/05/27 Python
Python基于PyGraphics包实现图片截取功能的方法
2017/12/21 Python
python获取依赖包和安装依赖包教程
2020/02/13 Python
简述数据库的设计过程
2015/06/22 面试题
学生会宣传部部长竞选演讲稿
2014/04/25 职场文书
李开复演讲稿
2014/05/24 职场文书
护校行动方案
2014/05/31 职场文书
小学教师师德师风自我剖析材料
2014/09/29 职场文书
2014年党支部工作总结
2014/11/13 职场文书
python实现层次聚类的方法
2021/11/01 Python
win10忘记pin密码登录不了怎么办?win10忘记pin密码登不进去的解决方法
2022/07/07 数码科技