判断字符串括号{}[]()是否闭合—python实现
生活随笔
收集整理的這篇文章主要介紹了
判断字符串括号{}[]()是否闭合—python实现
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
判斷字符串閉合是一道經典的面試題,首先要知道什么樣的括號是閉合的:{[{()}]()}?就是一個閉合的字符串。
{[{()}]([)]}?這個里面?([)]?括號不對稱,這種就是不閉合。
常見的解法是使用棧進行判斷,代碼如下:
def is_str_close():a = "{[()]}"b = []flag =0for i in a :if i=="{" or i=="[" or i=="(":b.append(i)elif i=="}" and b.pop()!="{":flag =1 elif i=="]" and b.pop()!="[":flag =1 elif i==")" and b.pop()!="(":flag =1 if len(b)!=0:flag=1 if flag==1:print("不閉合")elif flag==0:print("閉合")還有一種是不用棧的寫法,我覺得這種寫法更簡單更易于理解:
def is_str_close(a:string):a = "{[()]}"s1,s2,s3=0,0,0for i in range a:if i=="{":s1 += 1if i=="[":s2 += 1 if i=="(":s3 += 1 if i=="}":s1 -= 1if i=="]":s2 -= 1 if i==")":s3 -= 1 if s1!=0 or s2!=0 or s3!=0:print("不閉合")else:print("閉合")參考文章:
判斷字符串括號是否閉合(){}[]
python筆記45-經典面試題:判斷字符串括號是否閉合{}[]()
?
總結
以上是生活随笔為你收集整理的判断字符串括号{}[]()是否闭合—python实现的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 数据库性能优化—MySQL单表最大记录数
- 下一篇: Virtualenv系列(一):使用Vi