确定括号是否平衡的算法

确定括号是否平衡的算法

我开始发布一系列算法来帮助我们,我学习代码、英语并强化这一点。我希望能够帮助您并为社区做出贡献。

这个算法很容易理解,因为你的问题很简单,但它是一个很好的例子,让我们看看如何通过简单的步骤获得解决方案。

第一步是查看问题:

“我们将利用上一课中定义的堆栈数据结构来确定一组括号是否平衡。

让我们首先了解一组平衡的括号是什么样的。

一组平衡的括号是指左括号和右括号的数量和类型匹配,并且也正确嵌套在括号串内。” (educative.io)

平衡括号示例
{ }
{ } { }
( ( { [ ] } ) )
不平衡括号示例
( ( )
{ { { ) } ]
[ ] [ ] ]

解决这个问题你的第一个想法是什么?

解决此类问题的第二步是用笔在纸上(我喜欢使用简单的图表)我们可能使用的每个变量以及我们拥有的所有数据(这类似于解决物理问题)。

显示这个新示例“}]”

数组 = [“}”, “]”]

我们需要比较字符,看例子,很明显可以用数组来比较?

def is_match(p1, p2):    if p1 == "(" and p2 == ")":        return true    elif p1 == "{" and p2 == "}":        return true    elif p1 == "[" and p2 == "]":        return true    else:        return falsedef is_paren_balanced(paren_string):    s = stack()    is_balanced = true    index = 0    while index < len(paren_string) and is_balanced:        paren = paren_string[index]        if paren in "([{":            s.push(paren)        else:            if s.is_empty():                is_balanced = false                break            else:                top = s.pop()                if not is_match(top, paren):                    is_balanced = false                    break        index += 1    if s.is_empty() and is_balanced:        return true    else:        return false

我们声明是否平衡的步骤是验证数组的数量(在 % 2 != 0 中不起作用),并发现数组中是否存在用于输入的左括号,并使用 is_match 查找右括号。
当循环结束时,声明平衡或不平衡。

就是这样!

obs:我们需要使用栈数据结构。这个方法相信你都知道。

class Stack():    def __init__(self):        self.items = []    def push(self, item):        self.items.append(item)                 def pop(self):        return self.items.pop()    def is_empty(self):        return self.items == []    def peek(self):        if not self.is_empty():            return self.items[-1]    def get_stack(self):        return self.items

@vinycxuz

以上就是确定括号是否平衡的算法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1349982.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 13:51:27
下一篇 2025年12月13日 13:51:35

相关推荐

  • 使用 Sheepy 在 Python 中进行单元测试

    大家好,今天我来给大家介绍一个新的单元测试库,叫做sheepy,但是首先我们来谈谈单元测试的重要性。该库不适合初学者,要使用它进行单元测试,您需要额外注意。它仅具有用于使用端点和 http 错误检查模块进行 api 测试的断言。 github链接:githubpypi 链接:pypi 生产中所有成熟…

    好文分享 2025年12月13日
    000
  • 机器学习中的 C++:逃离 Python 和 GIL

    介绍 当 #%#$#%@%@%$#%$#%#%#$%@_23eeeb4347bdd26bfc++6b7ee9a3b755dd 的全局解释器锁 (gil) 成为需要高并发或原始性能的机器学习应用程序的瓶颈时,c++ 提供了一个引人注目的替代方案。这篇博文探讨了如何利用 c++ 进行机器学习,重点关注性…

    2025年12月13日
    000
  • 如何使用 Python 降低歌曲的音调

    如果您曾经想改变歌曲的音调而不改变其速度,那么这篇博文适合您。变调是音乐家、dj 和音频工程师的常见任务。在本教程中,我们将探索如何使用 python 和 pydub 库降低歌曲的音调,并将此过程自动应用于文件夹中的多首歌曲。 为什么要进行变调? 在音乐中,变调意味着改变歌曲的音调(升高或降低)而不…

    2025年12月13日
    000
  • python社区版和专业版区别

    Python 社区版和专业版的主要区别在于付费与免费。社区版适用于个人开发者、初学者和非营利组织,免费提供基本功能和社区支持。专业版适用于企业和组织,需要付费订阅,提供高级功能、技术支持和云部署选项。 Python 社区版和专业版之间的区别 主要区别: 主要区别在于付费与免费。 详细区别: 立即学习…

    2025年12月13日
    000
  • python社区版可以开发软件吗

    是,Python 社区版(CPython)可用于软件开发,因为它包含了必要的工具和库,包括核心解释器、标准库、各种工具和实用程序。它广泛用于开发网络应用程序、桌面应用程序、数据科学和机器学习项目,以及脚本和自动化任务。此外,它还提供了广泛的第三方库,扩展了其软件开发能力。 Python 社区版是否可…

    2025年12月13日
    000
  • pycharm社区版本下载教程

    如何下载 PyCharm 社区版本?访问 PyCharm 官网:https://www.jetbrains.com/pycharm/选择“下载”按钮并选择“社区”(免费)根据您的操作系统(Windows/MacOS/Linux)选择安装程序下载安装程序并按照提示安装 PyCharm PyCharm …

    2025年12月13日
    000
  • python怎么下载手机版

    可以通过 Python 下载手机应用:导入 os 和 requests 模块。获取要下载的应用链接。发送下载请求。检查响应状态代码。保存下载的应用。使用系统命令安装下载的应用(确保启用 USB 调试)。 如何通过 Python 下载手机应用 Python 是一种高级编程语言,可用于执行各种任务,包括…

    2025年12月13日
    000
  • python最新版本下载教程

    Python 最新版本可通过以下步骤下载:访问 Python 官网:https://www.python.org/根据操作系统选择安装程序运行安装程序验证安装(命令:python –version) Python 最新版本下载教程 引言Python 是目前最流行的编程语言之一,广泛应用于…

    2025年12月13日
    000
  • python下载视频源代码

    使用 Python 下载视频的方法:安装 requests 和 beautifulsoup4 库。确定要下载的视频的 URL。使用 requests 库发送 HTTP 请求并使用 BeautifulSoup 解析响应以提取视频来源。使用 requests 库再次发送请求以获取视频数据并写入本地文件。…

    2025年12月13日
    000
  • pycharm用社区版可以吗

    对于大多数 Python 开发人员来说,PyCharm 社区版足够满足其需求,它提供代码编辑、调试、测试、版本控制集成和可扩展性等核心功能。但是,它缺乏项目管理、数据库工具、远程开发和专业版中提供的其他高级功能。 PyCharm 社区版是否够用? 简介PyCharm 是一种流行的 Python 集成…

    2025年12月13日
    000
  • python3.9.2下载教程

    Python 3.9.2 下载步骤:访问官网下载页面:https://www.python.org/downloads/选择操作系统,下载对应安装程序安装 Python,按照提示完成操作 Python 3.9.2 下载教程 下载步骤: 访问官方下载页面:前往 Python 官网下载页面:https:…

    2025年12月13日
    000
  • python模拟电脑操作

    Python可模拟电脑操作,包括:鼠标移动:使用pyautogui库的moveTo和click方法。键盘输入:使用keyboard库的write、press和release方法。文件管理:使用os模块的exists、listdir、mkdir和remove函数。 Python 模拟电脑操作 导言 P…

    2025年12月13日
    000
  • python能抢票还能做什么

    Python 不仅用于抢票,还拥有广泛的应用,包括:数据分析与可视化网页爬取机器学习自动化任务Web 开发DevOps 和基础设施管理科学计算游戏开发 Python 的应用:从抢票到更多 Python 因其强大的抓取、自动化和数据处理功能而闻名。除了抢票之外,它还可以在各种领域发挥作用,为日常生活提…

    2025年12月13日
    000
  • 如何用Python抢火车票

    使用 Python 抢火车票分以下步骤:安装依赖项并导入库。创建浏览器实例并加载火车票预订网站。填写预订信息并提交。循环查找车次,找到符合条件的车次并点击预订按钮。填写乘客信息并确认订单。支付车票并关闭浏览器实例。 如何使用 Python 抢火车票 开门见山: 使用 Python 抢火车票需要以下步…

    2025年12月13日
    000
  • python怎么制作抢票软件

    如何使用 Python 制作抢票软件:安装 requests、BeautifulSoup4、lxml 软件包。向抢票网站发送 HTTP GET 请求,获取页面 HTML。解析 HTML,提取票务信息。设置定时器定期检查票务状态。检测到有票时自动发送购票请求。持续监视抢票状态直到成功或失败。 如何使用…

    2025年12月13日
    000
  • 自动抢票软件github

    自动抢票软件是一种自动预订火车票或机票的软件,具有自动抢票、多平台支持、自定义设置和高成功率的特点。您可以通过 GitHub、软件商店或第三方网站获取自动抢票软件。使用时需要注意选择信誉良好的软件、设置准确的抢票条件并做好抢票准备。 自动抢票软件 GitHub 自动抢票软件是什么? 自动抢票软件是一…

    2025年12月13日
    000
  • 用python识别火车票信息

    利用 Python 识别火车票信息可使用两种方法:基于模板匹配:准备火车票图像模板库,找到匹配度最高的模板,进而提取信息。基于图像处理:对图像进行预处理,分割关键区域,进行字符识别,并与火车票信息结构相匹配。 利用 Python 识别火车票信息 简介 火车票识别在火车票自动查询和管理系统中至关重要。…

    2025年12月13日
    000
  • 用python预约抢火车票

    使用 Python 编写脚本来自动预约抢票,提高抢票成功率。步骤包括:安装必要库、获取火车信息、编写抢票脚本(包括乘客信息、循环刷新查询、提交订单、支付订单)和运行脚本。 用 Python 抢火车票 使用 Python 编写脚本来自动预约抢票可以大大提高抢票成功率。 核心步骤: 安装必要的库。获取火…

    2025年12月13日
    000
  • 用python抢购预约商品

    通过 Python 编写自动化脚本,可以在预约时间反复发送预约请求,提高抢购成功率。 用 Python 抢购预约商品 简介 抢购预约商品通常是一项具有挑战性的任务,尤其是在需求量大的情况下。借助 Python,您可以编写自动化脚本,以提高抢购成功率。 步骤 立即学习“Python免费学习笔记(深入)…

    2025年12月13日
    000
  • python抢票用什么库比较快

    Python 抢票库为您提供快速抢票的机会。此类库包括:12306 为中国铁路抢票而设计。京东抢购适用于京东抢购。Pandas 帮助分析票务数据。Selenium 自动化填写表单和抢票。Requests 便于与抢票网站交互。Scrapy 抓取抢票网站信息。Beautiful Soup 解析 HTML…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信