基于python判断字符串括号是否闭合{}[]()
前言
经典面试题:判断一个字符串里面的括号是否闭合,如:{{()}}就是一个闭合的字符串。
{{()}]}这个里面([)]括号不对称,这种就是不闭合。
python判断闭合
解决基本思路:
先把左括号添加到一个列表里面,遇到右括号就弹出列表里面的最后一个存放进去的。
对比右括号和弹出的左括号是否对称,如果是就继续依次对比。
最后判断列表里面是否有多余的左括号,如果列表为空,说明全部被弹出,那就是闭合的
最后考虑下左括号和右括号有多余的情况
代码如下
defis_str_close(a):
'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
判断括号是否闭合
'''
b=[]
flag=True
foriina:
ifi=="{"ori=="["ori=="(":
#左边的括号加进去
b.append(i)
elifi=="}":
#遇到右边括号}弹出最后面的一个{
iflen(b)==0orb.pop()!="{":
returnFalse
elifi=="]":
#遇到右边括号]弹出最后面的一个[
iflen(b)==0orb.pop()!="[":
returnFalse
elifi==")":
#遇到右边括号)弹出最后面的一个(
iflen(b)==0orb.pop()!="(":
returnFalse
#判断最后列表b里面的左边括号是否全部被弹出
iflen(b)!=0:
flag=False
returnflag
if__name__=='__main__':
a="{[{()}]()}"
print(is_str_close(a))
b="({[{()}]()}"
print(is_str_close(b))
c="{[{()}]()}]"
print(is_str_close(c))
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。