• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

基于python判断字符串括号是否闭合{}[]()

python 搞代码 4年前 (2022-01-07) 39次浏览 已收录 0个评论

这篇文章主要介绍了基于python判断字符串括号是否闭合{}[](),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

前言

经典面试题: 判断一个字符串里面的括号是否闭合,如:{{()}} 就是一个闭合的字符串。

{{()}]} 这个里面 ([)] 括号不对称,这种就是不闭合。

python判断闭合

解决基本思路:

先把左括号添加到一个列表里面,遇到右括号就来源gaodai$ma#com搞$代*码网弹出列表里面的最后一个存放进去的。

对比右括号和弹出的左括号是否对称,如果是就继续依次对比。

最后判断列表里面是否有多余的左括号,如果列表为空,说明全部被弹出,那就是闭合的

最后考虑下左括号和右括号有多余的情况

代码如下

 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))

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持gaodaima搞代码网

以上就是基于python判断字符串括号是否闭合{}[]()的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:基于python判断字符串括号是否闭合{}[]()

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址