网络编程
位置:首页>> 网络编程>> Python编程>> 使用Python实现一个栈判断括号是否平衡

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

作者:soong  发布时间:2022-01-04 02:20:29 

标签:python,栈,括号,平衡

栈(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实现一个栈判断括号是否平衡网站的支持!

来源:https://juejin.im/post/5b7c01c9e51d45388325208a

0
投稿

猜你喜欢

  • 1.1.1 摘要 相信大家对于SQL Transcation再熟悉不过,它确保了数据库的数据一致性和安全性,尤其在对数据执行增删时,如果发生
  • 在SQL Server中进行开发会让你身处险地,并且寻找快速解决方案。我们编辑了前十名关于SQL Server开发的常见问题。对常见的针对表
  • 本文实例为大家分享了JS实现长图上下滚动的具体代码,供大家参考,具体内容如下案例描述将一张长图放在某一固定长宽的盒子里,当鼠标置于盒子的上半
  • 之前写过的组织结构和组织体系都太抽象了,读到标签系统我才有那种“略懂”的感觉。哈哈…书上提到的标签包括:导航情境式链接:常见的“更多”这种用
  • 需求背景:进行分值计算。如下图,如果只是一两个还好说,写写判断,但是如果有几十个,几百个,会不会惨不忍睹。而且,下面的还是三种情况。例如:解
  • 七牛云存储的 Python 语言版本 SDK(本文以下称 Python-SDK)是对七牛云存储API协议的一层封装,以提供一套对于 Pyth
  •  代码如下:---ntext数据类型字符替换 create table tt ( sid INT IDENTITY(1,1), c
  • 1. Python的figure参数主要有:def figure(num=None, # autoincrement if None, el
  • 有时候发微博时候,需要裁切图片为九宫格,但是ps或者其他工具都太麻烦,这里写一个python一键切割九宫格的工具,以供大家学习和使用!实现代
  • 总经一下前段时间用于的jQuery方法:find及children。需要的朋友可以参考下。首先看看英文解释吧: children方法:fin
  • 前言第一次看go基础语法的时候,用使用到了defer。但是一直不知道它到底是什么,有什么用途。这几天通过查询、学习。算是对defer有了一点
  • 做一个总结,把自己这些年的从业经历和观感罗列一下,某些话可能触及到个人神经,但它们没有恶意。设计师喜欢把世界想象得很美好,社会很和谐,但是这
  • 以发布目录为例:<OBJECT ID="agobjOraSession" RUNAT=&quo
  • 目的是想通过给定一个ID,取出所有的子ID,包括子ID的子ID。一开始写成FUNCTION,因为FUNCTION调用方便,但是报错:ERRO
  • 写任何编程代码,不同的开发者都会有不同的见解。但参考一下总是好的,下面是来自 Javascript Toolbox 发布的 14条最佳JS代
  • 不同于其他软件项目,互联网项目的开发有其独有的特性。互联网项目开发不同于传统软件项目开发不同于需求定制性的软件开发公司。客户的需求是明确的,
  • 导语:近年来,全世界都纷纷投身网络热潮。从小企业到大公司,再到网络学校和大学,大家都在努力提升自己的网络影响力,这样既免费为自身品牌做广告,
  • 适配器模式Adapter Pattern是什么适配器模式是一种结构型模式,它可以将一个类的接口转换成客户端所期望的接口,从而使原本不兼容的类
  • 我们需要将【小组销量排名表.xlsx】通过邮件发送给【组长邮箱.xlsx】中的各个组长。这里会学一个新的知识点&mdash;&
  • 很多时候关心的是优化SELECT 查询,因为它们是最常用的查询,而且确定怎样优化它们并不总是直截了当。相对来说,将数据装入数据库是直截了当的
手机版 网络编程 asp之家 www.aspxhome.com