首页 > 编程问答 >检查括号和方括号是否平衡

检查括号和方括号是否平衡

时间:2024-08-09 03:13:44浏览次数:7  
标签:python

我需要编写一个函数,给出带有括号和/或方括号的字符串,它能够评估它们是否以正确的顺序出现。例如,在此字符串 '([b])(aa)' 中,您可以看到每次打开括号或方括号时,它都会在正确的位置关闭。但是,像“[(a])”这样的字符串不会以正确的顺序关闭括号或方括号,因为它应该是“[(a)]”。

该函数应该根据此返回 True 或 False两个元素的正确位置。我已经尝试了以下代码,但这个逻辑似乎是无限的,如果我打开了两个以上的括号或方括号,它就不起作用。

def parenthesis(string):
  for a in range(len(string)):
    if string[a] == "(":
      for b in range(a,len(string)):
        if string[b] == "[":
          for c in range(b,len(string)):
            if string[c] == "]":
              for d in range(c,len(string)):
                if string[d] == ")":
                  return True
        elif string[b] == ")":
          return True
        else:
          return False

如果我在字符串“([b])(aa上运行该函数)" 它返回 false 作为输出。

parenthesis("([b])(aa)")

如何重写此函数,以便正确评估所有括号和方括号组合?


的代码的问题在于,它试图通过从左到右遍历字符串来立即匹配任何类型的开启括号(“(”或“[”)与任何类型的闭合括号(“)”或“]”)相匹配。这是不正确的,因为它需要考虑括号的嵌套顺序。

以下是一个使用栈来解决此问题的 Python 函数的更正版本:

def is_balanced(string):
  """检查字符串中的括号和方括号是否平衡。

  参数:
    string: 要检查的字符串。

  返回值:
    如果字符串中的括号和方括号平衡,则为 True,否则为 False。
  """
  stack = []
  brackets = {")": "(", "]": "["}
  for char in string:
    if char in "([":
      # 如果是开启括号,则将其压入栈中。
      stack.append(char)
    elif char in ")]":
      # 如果是闭合括号,则检查栈是否为空。
      if not stack:
        return False
      # 如果栈不为空,则弹出栈顶元素。
      top = stack.pop()
      # 如果弹出的元素与当前的闭合括号不匹配,则返回 False。
      if brackets[char] != top:
        return False
  # 如果字符串遍历完毕后,栈为空,则返回 True,否则返回 False。
  return not stack

该函数的工作原理如下:

  1. 它创建一个空栈来存储开启括号。
  2. 它遍历字符串中的每个字符。
  3. 如果字符是开启括号(“(”或“[”),则将其压入栈中。
  4. 如果字符是闭合括号(“)”或“]”),则检查栈是否为空。如果栈为空,则表示没有相应的开启括号,因此字符串不平衡,函数返回 False
  5. 如果栈不为空,则弹出栈顶元素。
  6. 检查弹出的元素是否与当前的闭合括号匹配。如果它们不匹配,则表示字符串不平衡,函数返回 False
  7. 如果字符串遍历完毕后,栈为空,则表示所有括号都已正确匹配,因此字符串平衡,函数返回 True 。否则,表示存在未匹配的开启括号,字符串不平衡,函数返回 False

以下是一些使用该函数的示例:

print(is_balanced("([b])(aa)"))  # True
print(is_balanced("[(a])"))  # False
print(is_balanced("([)]"))  # False
print(is_balanced("((()))"))  # True
print(is_balanced("(()"))  # False
print(is_balanced("([{}])"))  # True

标签:python
From: 72250748

相关文章

  • Python 和 Excel:将数据放入另一个函数中,然后从中获取信息
    我正在尝试将温度/压力数据放入蒸汽表以获得过热焓数据。我已经成功地获取了数据并将其放入Excel文件中,然后它为我提取了焓数据。问题是,当我将温度和压力数据放入蒸汽表时,它实际上并没有进行双重插值,因此焓(H)值实际上从未改变ng。我最终只得到了蒸汽数据中给出......
  • Python 类型提示:显式排除无效的重载组合?
    我有一个带有两个参数的函数,每个参数都可以采用两种类型之一。四个成对组合中的三个有效,但第四个无效。我想找到一种方法来键入提示此场景,可以检查这些类型,但不一定每次调用foo()时都必须编写代码来检查无效情况。有没有办法可以改进foo()、bar()或两......
  • 我在制作 python 语音应用程序时遇到错误
    我编写了一个语音聊天应用程序代码,但是当我们运行此代码并加入语音频道时,我收到照片中的错误错误1错误2这是我的代码;客户端代码:importtkinterastkfromtkinterimportmessageboximportpyaudioimportsocketimportthreadingimporttimeHOST=......
  • pyocr,一个超酷的Python库!
    pyocr是一个用于光学字符识别(OCR)的Python库,它提供了一个简单的接口,允许开发者将图片中的文本提取出来。这个库是对Tesseract-OCR的封装,使得在Python环境中使用OCR技术变得更加便捷。如何安装pyocr首先,要使用pyocr库,您需要安装它。可以使用pip包管理工具来进......
  • pattern,一款超牛的Python库
    在程序开发中,处理文本数据和进行自然语言处理是常见需求。pattern是一个强大的Python库,专为文本分析而设计,提供了丰富的功能,包括自然语言处理、数据挖掘和网络分析等。它简单易用,让程序员能够快速实现复杂的文本处理任务。如何安装pattern在开始使用pattern库之前,首先......
  • 【Playwright+Python】系列教程(八)鉴权Authentication的使用
    写在前面还是有些絮叨的感觉,官方翻译和某些博主写那个玩楞,基本都是软件直接翻译后的产物。读起来生硬不说,甚至有的时候不到是什么意思,真的是实在不敢恭维。到底是什么意思?就是你已经登陆过一次,在Session、Cookie未失效的情况下,登录过一次后,下次就不用再走一遍登录的过程,从而缩......
  • 基于CNN-GRU-Attention混合神经网络的负荷预测方法(Python代码实现)
    ......
  • Python和AI库NumPy(二):数组创建与操作的深入探索
    目录1.数组创建1.1基本数组创建1.2使用内置函数创建数组1.3特殊数组的创建2.数组的基本操作2.1数组属性2.2数组索引和切片2.3数组的形状操作2.4数组拼接与分割3.数组的数学操作3.1基本算术操作3.2广播机制3.3线性代数运算4.高级数组操作4.1花式......
  • 如何为本地python共享文件网页配置公网地址实现跨网络远程访问
    文章目录前言1.本地文件服务器搭建1.1.Python的安装和设置1.2.cpolar的安装和注册2.本地文件服务器的发布2.1.Cpolar云端设置2.2.Cpolar本地设置3.公网访问测试4.结语前言本文主要介绍如何在Windows系统电脑上使用python这样的简单程序语言,在自己的电脑上搭建一个......
  • 基于YOLOv10深度学习的交通信号灯检测识别系统【python源码+Pyqt5界面+数据集+训练代
    《博主简介》小伙伴们好,我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。✌更多学习资源,可关注公-仲-hao:【阿旭算法与机器学习】,共同学习交流~......