使用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应用的教程
Apr 16 Python
python实现在字符串中查找子字符串的方法
Jul 11 Python
基于数据归一化以及Python实现方式
Jul 11 Python
python二进制文件的转译详解
Jul 03 Python
TensorFlow基于MNIST数据集实现车牌识别(初步演示版)
Aug 05 Python
Python通过Manager方式实现多个无关联进程共享数据的实现
Nov 07 Python
Python中的X[:,0]、X[:,1]、X[:,:,0]、X[:,:,1]、X[:,m:n]和X[:,:,m:n]
Feb 13 Python
解决Python spyder显示不全df列和行的问题
Apr 20 Python
pandas中的ExcelWriter和ExcelFile的实现方法
Apr 24 Python
python -v 报错问题的解决方法
Sep 15 Python
python实现的web监控系统
Apr 27 Python
PyTorch dropout设置训练和测试模式的实现
May 27 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代码优化的53个细节
2014/03/03 PHP
thinkphp3.x中display方法及show方法的用法实例
2016/05/19 PHP
thinkPHP框架实现多表查询的方法
2018/06/14 PHP
php实现JWT(json web token)鉴权实例详解
2019/11/05 PHP
取得窗口大小 兼容所有浏览器的js代码
2011/08/09 Javascript
jQuery实现 注册时选择阅读条款 左右移动
2013/04/11 Javascript
jQuery层次选择器选择元素使用介绍
2013/04/18 Javascript
Javascript实现重力弹跳拖拽运动效果示例
2013/06/28 Javascript
jquery click([data],fn)使用方法实例介绍
2013/07/08 Javascript
在AngularJS中使用jQuery的zTree插件的方法
2016/04/21 Javascript
一系列Bootstrap导航条使用方法分享
2016/04/29 Javascript
基于bootstrap实现bootstrap中文网巨幕效果
2017/05/02 Javascript
js每隔两秒输出数组中的一项(实例)
2017/05/28 Javascript
用ES6的class模仿Vue写一个双向绑定的示例代码
2018/04/20 Javascript
node.js实现上传文件功能
2019/07/15 Javascript
javascript事件循环event loop的简单模型解释与应用分析
2020/03/14 Javascript
js实现贪吃蛇小游戏(加墙)
2020/07/31 Javascript
用JavaScript实现贪吃蛇游戏
2020/10/23 Javascript
python使用原始套接字发送二层包(链路层帧)的方法
2019/07/22 Python
使用python批量修改文件名的方法(视频合并时)
2020/03/24 Python
初中生物教学反思
2014/01/10 职场文书
新员工欢迎词
2014/01/12 职场文书
财务科科长岗位职责
2014/03/10 职场文书
小学生期末评语大全
2014/04/21 职场文书
《蜗牛的奖杯》教后反思
2014/04/24 职场文书
2014年重阳节活动策划方案书
2014/09/16 职场文书
事业单位个人查摆问题及整改措施
2014/10/28 职场文书
高校自主招生校长推荐信
2015/03/23 职场文书
2015年人事工作总结范文
2015/04/09 职场文书
2015年房产经纪人工作总结
2015/05/15 职场文书
教师节表彰会主持词
2015/07/06 职场文书
三八红旗手主要事迹材料
2015/11/04 职场文书
《山中访友》教学反思
2016/02/24 职场文书
2016年清明节期间群众祭祀活动工作总结
2016/04/01 职场文书
2019终止劳动合同协议书最新范本!
2019/07/09 职场文书
Apache Hudi 加速传统的批处理模式
2022/04/24 Servers