使用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中关于日期时间处理的问答集锦
Mar 08 Python
Python图算法实例分析
Aug 13 Python
详解Python 序列化Serialize 和 反序列化Deserialize
Aug 20 Python
Python处理中文标点符号大集合
May 14 Python
PyQt5实现类似别踩白块游戏
Jan 24 Python
Python selenium根据class定位页面元素的方法
Feb 26 Python
Python多继承以及MRO顺序的使用
Nov 11 Python
python PIL/cv2/base64相互转换实例
Jan 09 Python
python GUI库图形界面开发之PyQt5信号与槽多窗口数据传递详细使用方法与实例
Mar 08 Python
win10下python3.8的PIL库安装过程
Jun 08 Python
Python使用sys.exc_info()方法获取异常信息
Jul 23 Python
python 密码学示例——凯撒密码的实现
Sep 21 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
Get或Post提交值的非法数据处理
2006/10/09 PHP
php实现修改新闻时删除图片的方法
2015/05/12 PHP
PHP中的事务使用实例
2015/05/26 PHP
PHP微信开发之根据用户回复关键词\位置返回附近信息
2016/06/24 PHP
JavaScript asp.net 获取当前超链接中的文本
2009/04/14 Javascript
利用JQuery为搜索栏增加tag提示
2009/06/22 Javascript
JavaScript和ActionScript的交互实现代码
2010/08/01 Javascript
javascript写的简单的计算器,内容很多,方法实用,推荐
2011/12/29 Javascript
js 连接数据库如何操作数据库中的数据
2012/11/23 Javascript
bootstrap table分页模板和获取表中的ID方法
2017/01/10 Javascript
数组Array的排序sort方法
2017/02/17 Javascript
vue3.0 CLI - 2.3 - 组件 home.vue 中学习指令和绑定
2018/09/14 Javascript
vue发送websocket请求和http post请求的实例代码
2019/07/11 Javascript
详解JS深拷贝与浅拷贝
2020/08/04 Javascript
Python排序搜索基本算法之堆排序实例详解
2017/12/08 Python
python中验证码连通域分割的方法详解
2018/06/04 Python
Python3使用PySynth制作音乐的方法
2019/09/09 Python
python温度转换华氏温度实现代码
2020/12/06 Python
英格兰橄榄球商店:England Rugby Store
2016/12/17 全球购物
Foreo国际站:Foreo International
2018/10/29 全球购物
J2EE包括哪些技术
2016/11/25 面试题
县优秀教师事迹材料
2014/01/31 职场文书
工程师岗位职责规定
2014/02/26 职场文书
《欢乐的泼水节》教学反思
2014/04/22 职场文书
宣传普通话标语
2014/06/27 职场文书
公司授权委托书样本
2014/09/15 职场文书
教育局党的群众路线教育实践活动整改方案
2014/09/20 职场文书
大学拉赞助协议书范文
2014/09/26 职场文书
工伤死亡理赔协议书
2014/10/20 职场文书
2014年远程教育工作总结
2014/12/09 职场文书
优秀班主任事迹材料
2014/12/16 职场文书
青年教师听课心得体会
2016/01/15 职场文书
导游词之江南园林狮子林
2019/09/16 职场文书
解决vue $http的get和post请求跨域问题
2021/06/07 Vue.js
DIV CSS实现网页背景半透明效果
2021/12/06 HTML / CSS
Redis基本数据类型String常用操作命令
2022/06/01 Redis