亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python怎么實現求解括號匹配問題

發布時間:2021-03-24 13:43:38 來源:億速云 閱讀:140 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關Python怎么實現求解括號匹配問題,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

主要的思路:

首先設置兩個列表分別存放的是各種括號的開括號和閉括號,然后遍歷給定的字符串,分如下幾種情況:

1.字符串首字符出現在閉括號列表中,直接結束,輸出錯誤

2.字符串長度不為偶數,直接結束,輸出錯誤

3.對原始字符串列表化去重,如果去重后的列表長度不為偶數直接結束,輸出錯誤

4.遍歷字符串,將屬于開括號集合的括號加入到列表中,當遇上一個閉括號的時候計算該閉括號在閉括號列表中的索引與當前列表最后一個開括號在開括號列表中的索引是否一致,一致則繼續,否則直接結束,輸出錯誤

主要是在長度很大的時候可以盡快判斷一些比較明顯的錯誤的模式,節省時間,按照這個簡單的思想,下面是具體的實現:

#!usr/bin/env python
#encoding:utf-8
'''''
__Author__:沂水寒城
功能:括號匹配的相關問題
'''
def bracket_mathch(one_str):
 '''''
 括號匹配
 '''
 tmp_list=[]
 open_bracket_list=['(','[','{','<','《']
 close_bracket_list=[')',']','}','>','》']
 one_str_list=list(one_str)
 length=len(one_str_list)
 set_list=list(set(one_str_list))
 num_list=[one_str_list.count(one) for one in set_list]
 if one_str[0] in close_bracket_list:
  return False
 elif length%2!=0:
  return False
 elif len(set_list)%2!=0:
  return False
 else:
  for i in range(length):
   if one_str[i] in open_bracket_list:
    tmp_list.append(one_str[i])
   elif one_str[i] in close_bracket_list:
    if close_bracket_list.index(one_str[i])==open_bracket_list.index(tmp_list[-1]):
     tmp_list.pop()
    else:
     return False
     break
 return True
if __name__ == '__main__':
 one_str_list=['({})','({[<《》>]})','[(]){}','{{{{{{','([{}])','}{[()]']
 for one_str in one_str_list:
  if bracket_mathch(one_str):
   print one_str, '正確'
  else:
   print one_str, '錯誤'
 tmp='{}[{()()[]<{{[[[[(())()()(){}[]{}[]()<>]]]]}}>}]'
 print bracket_mathch(tmp)

結果如下:

Python怎么實現求解括號匹配問題

關于“Python怎么實現求解括號匹配問題”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

蓬溪县| 离岛区| 邵阳县| 和田县| 高碑店市| 昭觉县| 始兴县| 灵寿县| 上林县| 湖州市| 丽江市| 曲沃县| 安溪县| 阿坝县| 石楼县| 武穴市| 株洲县| 博爱县| 江口县| 伊通| 昌吉市| 克什克腾旗| 容城县| 唐海县| 区。| 姚安县| 揭阳市| 霍邱县| 白城市| 准格尔旗| 山丹县| 石门县| 泌阳县| 武邑县| 莱西市| 永昌县| 汤阴县| 工布江达县| 连平县| 延边| 富川|