亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Python > 正文

Python實現括號匹配方法詳解

2020-02-15 21:17:39
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了python實現括號匹配方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

1.用一個?!緋ython中可以用List】就可以解決,時間和空間復雜度都是O(n)

# -*- coding: utf8 -*-# 符號表SYMBOLS = {'}': '{', ']': '[', ')': '(', '>': '<'}SYMBOLS_L, SYMBOLS_R = SYMBOLS.values(), SYMBOLS.keys()def check(s):  arr = []  for c in s:    if c in SYMBOLS_L:      # 左符號入棧      arr.append(c)    elif c in SYMBOLS_R:      # 右符號要么出棧,要么匹配失敗      if arr and arr[-1] == SYMBOLS[c]:        arr.pop()      else:        return False  return Trueprint(check("3 * {3 +[(2 -3) * (4+5)]}"))print(check("3 * {3+ [4 - 6}]"))

2.

# 存儲左括號和右括號open_brackets = '([{<'close_brackets = ')]}>'# 映射左右括號便于出棧判斷brackets_map = {')': '(', ']': '[', '}': '{', '>': '<'}# 對于每一行數據,進行如下判定若括號為左括號,加入棧,若括號為右括號,判斷是否跟棧尾括號對應, 若對應,彈出棧尾元素,若所有括號均正確閉合,則最后棧為空。for row in rows:  stack = []  label = True  for char in row:    if char in open_brackets:      stack.append(char)    elif char in close_brackets:      if len(stack) < 1:        label = False        break      elif brackets_map[char] == stack[-1]:        stack.pop()      else:        label = False        break    else:      continue  if stack != []:    label = False  print(label)rows = ['([<^>x[ ]{a}]{/}{t}g<^>)<{x}b>{x}<z({%}w >[b][c[c]]{<h>{h}}', '[/]{((x)({{*}*}w)w){f}{v}[%(^[z]{u}{ })([[ ]-]h)]{c}(*)[y]}', '<<(^)z>>[b]< >[[(c)u[v]{z<b< >><b>}]g][/b[(])v(v)(+)](v)', '[[b]][(v)g]<z>([{{<->+}e}[*]d<+>]g[[a] <+>(v)<e>]){a}[u]']

3.

在長度很大的時候可以盡快判斷一些比較明顯的錯誤的模式,節省時間:

主要的思路:

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

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

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

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

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

#!usr/bin/env python# encoding:utf-8def 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 Trueif __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))            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产99久久精品一区二区 夜夜躁日日躁| 国产精品电影网| 欧美日产国产成人免费图片| 91影院在线免费观看视频| 久热爱精品视频线路一| 国产91在线播放九色快色| 超碰日本道色综合久久综合| 成人免费大片黄在线播放| 日韩av最新在线观看| 永久免费毛片在线播放不卡| 国产视频精品久久久| 97精品伊人久久久大香线蕉| 亚洲aⅴ日韩av电影在线观看| 久久成人av网站| 欧美亚洲一级片| 欧美激情精品久久久久久黑人| 日韩亚洲在线观看| 国产亚洲精品91在线| 亚洲伊人久久大香线蕉av| 国产97在线|亚洲| 亚洲欧美日韩一区二区三区在线| 亚洲女成人图区| 欧美视频在线免费| 中文字幕不卡在线视频极品| 国产成人一区二区三区小说| 欧美国产日韩一区二区三区| 亚洲毛片一区二区| 亚洲黄一区二区| 日韩在线中文字| 91九色综合久久| 中文字幕亚洲图片| 久久久精品在线| 亚洲国产美女久久久久| 色综合天天综合网国产成人网| 国产日韩换脸av一区在线观看| 国产精品久久久久久久久免费| 国产精品人人做人人爽| 久久99视频免费| 欧美高清videos高潮hd| 国产精品99久久久久久白浆小说| 亚洲精品国产精品久久清纯直播| 91精品视频观看| 2023亚洲男人天堂| 日韩高清免费观看| 伊人男人综合视频网| 亚洲精品国产电影| 日韩电视剧在线观看免费网站| 97超碰国产精品女人人人爽| 欧美午夜视频在线观看| 欧美日韩免费看| 久久久亚洲欧洲日产国码aⅴ| 久久精品国产69国产精品亚洲| 国产一区二区三区在线观看网站| 97国产在线观看| 欧美极度另类性三渗透| 在线播放国产一区中文字幕剧情欧美| 国产成+人+综合+亚洲欧洲| 欧美中文在线免费| 欧美www视频在线观看| 亚洲少妇激情视频| 亚洲精品一区中文| 日韩av在线一区| …久久精品99久久香蕉国产| 精品视频—区二区三区免费| 国产激情视频一区| 亚洲色图第一页| 欧美激情xxxx| 91av免费观看91av精品在线| 久久天堂电影网| 亚洲精品美女在线观看| 97超级碰在线看视频免费在线看| 中文字幕日韩免费视频| 国内外成人免费激情在线视频网站| 欧美成人免费全部观看天天性色| 精品一区二区三区电影| 91亚洲国产精品| 色婷婷综合成人av| 亚洲va国产va天堂va久久| 欧美一区二区影院| 久久中文字幕一区| 亚洲国产精品va在看黑人| 亚洲成人av片| 深夜精品寂寞黄网站在线观看| 亚洲欧洲自拍偷拍| 欧美性猛交xxxxx免费看| 久久噜噜噜精品国产亚洲综合| 日韩欧美在线免费观看| 国产精品日韩电影| 欧美老少做受xxxx高潮| 久久6免费高清热精品| 欧美视频在线免费看| 欧美日韩激情视频8区| 久久精品精品电影网| 91在线观看免费高清完整版在线观看| 亚洲天堂色网站| 国产亚洲精品久久久久久777| 色婷婷成人综合| 亚洲最大av在线| 92看片淫黄大片欧美看国产片| 日韩av免费看| 国产一区二区三区在线观看视频| 国产在线拍偷自揄拍精品| 欧美日韩成人精品| 国产福利精品av综合导导航| 亚洲国产成人av在线| 久久成人综合视频| 久久精品在线播放| 欧美亚洲免费电影| 国产成人精品在线观看| 成人做爽爽免费视频| 国产女人18毛片水18精品| 日本高清视频一区| 久久久久久久久久久av| 亚洲精品美女在线观看播放| 91免费看视频.| 成人在线中文字幕| 97色在线观看| 欧洲午夜精品久久久| 中日韩美女免费视频网址在线观看| 日韩av免费在线| 国产欧美日韩精品专区| 久久久精品网站| 国产美女精品免费电影| 亚洲视频国产视频| 久久精品视频99| 精品中文字幕在线| 欧美成人精品一区| 成人精品一区二区三区电影免费| 亚洲一二三在线| 久久精品一本久久99精品| 久久91精品国产91久久久| 一区二区三区回区在观看免费视频| 久久久久久久久久久国产| 欧美一区二粉嫩精品国产一线天| 欧美综合第一页| 性欧美办公室18xxxxhd| 色婷婷av一区二区三区久久| 亚洲综合av影视| 国产成人拍精品视频午夜网站| 亚洲精品久久久久久久久| 国产日产欧美精品| 国内外成人免费激情在线视频网站| 欧美另类交人妖| 中文字幕亚洲欧美日韩在线不卡| 欧洲中文字幕国产精品| 亚洲综合精品伊人久久| 国产伊人精品在线| 欧美成人精品h版在线观看| 国产91精品最新在线播放| 成人久久18免费网站图片| 精品亚洲一区二区三区在线观看| 欧美一区视频在线| 亚洲高清福利视频| 中文精品99久久国产香蕉| 国产精品久久久久久久久久免费| 亚洲激情自拍图| www.亚洲成人| 亚洲国产成人精品久久| 亚洲性xxxx| 亚洲男人天堂2024| 亚洲精品一区二区三区不| 亚洲影院色无极综合| 国产91热爆ts人妖在线| 国产成人精品在线|