怎么用Python解决括号匹配问题
发表于:2025-02-04 作者:千家信息网编辑
千家信息网最后更新 2025年02月04日,这篇文章主要介绍"怎么用Python解决括号匹配问题",在日常操作中,相信很多人在怎么用Python解决括号匹配问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"怎么用
千家信息网最后更新 2025年02月04日怎么用Python解决括号匹配问题
这篇文章主要介绍"怎么用Python解决括号匹配问题",在日常操作中,相信很多人在怎么用Python解决括号匹配问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"怎么用Python解决括号匹配问题"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
整体实现思路:借助Python 的List 来实现 ,因为列表的Append 方法相当于栈的Push 方法即栈的压入,列表的Pop 方法相当于栈的Pop 方法即弹出。
详细的思路:
首先,设置一个字典,用于存放我们要遍历的符号类型。
其次,是设置两个列表分别存放的是各种括号的开括号和闭括号,然后遍历给定的字符串,分如下几种情况:
字符串为空时直接输出True
字符串的符号不成对匹配时输出False
字符串中的符号不是字典中的符号类型时,直接忽略
遍历字符串,将正向的符号压入栈内,遍历到的字符如果是正向符号(正好是最近的一个符号时)的匹配内容就弹出栈
代码实现如下:
#定义要检查匹配的符号类型
brackets = {'}': '{', ']': '[', ')': '(', '>': '<'}
#将符号的正反向进行分类
bracket_l, brackets_r = brackets.values(), brackets.keys()
#定义一个检查字符串的方法
def check(str1):
alist = [] #定义一个空列表
for c in str1:
if c in bracket_l:
alist.append(c)#将左符号压入栈内
elif c in brackets_r:#右符号要么出栈,要么匹配失败,不做处理
if alist and alist[-1] == brackets[c]:#判断alist不会空且alist最后一个字符等于左符号对应的右符号时
alist.pop() #就做出栈操作
else:
return False
return True #传入空的字符串直接返回true
if __name__ == '__main__':
print(check("6c[*]{7b +[(8e -s3) * (d4+t5)]}<<>>"))
print(check("6c*{7b+ [8e- 9f]}<>"))
print(check(""))
到此,关于"怎么用Python解决括号匹配问题"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
符号
字符
括号
字符串
方法
问题
学习
类型
字典
思路
更多
要么
帮助
检查
输出
实用
接下来
两个
代码
内容
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络技术的安全与发展论文
网络安全中的http协议
java上传文件到数据库
福建物联网子母钟服务器
软件开发功能联调
辽宁数据软件开发服务标准
23魔方家谱数据库
软件开发合作框架协议合同范本
网络安全行业元宵节
全国网络安全讲话心得
数据库中价格是什么类型
网络安全法三十八条
我的世界服务器表情插件下载
怎么到北美服务器玩魔兽
浙江大型软件开发诚信经营
ros系统启动服务器命令
建筑市场信息数据库管理办法
计算机网络技术从哪里学
xml文件 数据库
邵阳正规软件开发费用
2017年9月网络安全月
智慧城市网络安全吗
中国移动网络安全运营中心
达梦数据库如何测试
原神服务器
北京it 软件开发常用解决方案
怀旧服服务器猎人训练点
网络技术设计logo
科技生活互联网
邵阳正规软件开发费用