基于python判断字符串括号是否闭合{}[]()
- 更新时间:2022-10-18 08:59:03
- 编辑:牛元明
前言
经典面试题: 判断一个字符串里面的括号是否闭合,如:{{()}} 就是一个闭合的字符串。
{{()}]} 这个里面 ([)] 括号不对称,这种就是不闭合。
python判断闭合
解决基本思路:
先把左括号添加到一个列表里面,遇到右括号就弹出列表里面的最后一个存放进去的。
对比右括号和弹出的左括号是否对称,如果是就继续依次对比。
最后判断列表里面是否有多余的左括号,如果列表为空,说明全部被弹出,那就是闭合的
最后考虑下左括号和右括号有多余的情况
代码如下
def is_str_close(a): ''' 遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939 寻找有志同道合的小伙伴,互帮互助,群 里还有不错的视频学习教程和PDF电子书! 判断括号是否闭合 ''' b = [] flag = True for i in a: if i == "{" or i == "[" or i == "(": # 左边的括号加进去 b.append(i) elif i == "}": # 遇到右边括号}弹出最后面的一个{ if len(b) == 0 or b.pop() != "{": return False elif i == "]": # 遇到右边括号]弹出最后面的一个[ if len(b) == 0 or b.pop() != "[": return False elif i == ")": # 遇到右边括号)弹出最后面的一个( if len(b) == 0 or b.pop() != "(": return False # 判断最后列表b里面的左边括号是否全部被弹出 if len(b) != 0: flag = False return flag if __name__ == '__main__': a = "{[{()}]()}" print(is_str_close(a)) b = "({[{()}]()}" print(is_str_close(b)) c = "{[{()}]()}]" print(is_str_close(c))
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持码农之家。
相关教程
-
用Python来搭建一个简单的推荐系统实例讲解
这篇文章主要介绍了如何用Python来搭建一个简单的推荐系统,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
发布时间:2021-05-18
-
Python pandas模块输出每行中间省略号问题及解决方法
这篇文章主要介绍Python pandas模块输出每行中间省略号问题,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
发布时间:2019-08-11
-
win10下python3.5.2、tensorflow和matplotlib安装教程
今天小编就为大家分享一篇关于python爬虫常用库的安装及其环境配置的文章,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
发布时间:2018-09-19
-
python生成n个元素的实例代码
今天小编就为大家分享一篇python生成n个元素的全组合方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
发布时间:2021-05-02
-
分享Python输出由1,2,3,4组成的互不相同且无重复的三位数代码
这篇文章主要介绍了Python输出由1,2,3,4组成的互不相同且无重复的三位数,分享了相关代码示例,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下
发布时间:2020-02-04
-
怎样使用python自定义时钟类、定时任务类
这篇文章主要为大家详细介绍了Python自定义时钟类、定时任务类,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
发布时间:2020-02-03
-
python里协程使用同步锁Lock的代码分析
今天小编就为大家分享一篇在python里协程使用同步锁Lock的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
发布时间:2020-01-17