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

首頁 > 編程 > Python > 正文

python實現括號匹配的思路詳解

2020-02-15 22:48:30
字體:
來源:轉載
供稿:網友

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
国产精品入口日韩视频大尺度| 精品日韩中文字幕| 91av免费观看91av精品在线| 一本色道久久综合狠狠躁篇的优点| 欧美日韩电影在线观看| 亚洲一品av免费观看| 国产成人一区二区三区小说| 97免费视频在线| 国产精品成人在线| 国产一区二区免费| 国产成人一区二区| 成人精品一区二区三区电影黑人| 欧美日韩激情视频8区| 国产精品美女呻吟| 国产成人精品国内自产拍免费看| 波霸ol色综合久久| 亚洲国产精品人人爽夜夜爽| 青青久久av北条麻妃黑人| 久久精品视频在线| 欧美在线观看一区二区三区| 国产专区欧美专区| 欧美性视频精品| 国产精品欧美久久久| 成人有码视频在线播放| 亚洲国产精品va在线看黑人| 97精品在线观看| 精品国产鲁一鲁一区二区张丽| 国产69精品久久久久99| 中文字幕欧美专区| 中文字幕精品一区久久久久| 亚洲高清色综合| 日韩黄色在线免费观看| 国产999精品久久久影片官网| 亚洲精品av在线播放| 久久免费国产精品1| 精品国产美女在线| 91在线看www| 成年人精品视频| 亚洲人成电影网站色xx| 国产一区二区三区在线免费观看| 永久免费精品影视网站| 国产第一区电影| 永久555www成人免费| 亚洲r级在线观看| 在线观看中文字幕亚洲| 国产精品视频久久久| 91牛牛免费视频| 91精品在线播放| 亚洲成色777777在线观看影院| 岛国av在线不卡| 91精品久久久久久久久久久久久| 97精品视频在线播放| 亚洲最大福利网| 欧美在线一区二区三区四| 国产精品天天狠天天看| 在线观看国产精品淫| 中文字幕亚洲国产| 亚洲精品电影在线观看| 亚洲91精品在线观看| 亚洲免费精彩视频| 亚洲电影免费观看高清完整版在线观看| 亚洲午夜精品视频| 国产欧美一区二区| 久久综合伊人77777尤物| 欧美精品福利在线| 国产精品激情自拍| 亚洲高清久久久久久| 69**夜色精品国产69乱| 久久久精品一区| 日韩天堂在线视频| 亚洲午夜久久久久久久| 亚洲片在线观看| 亚洲欧美日韩国产成人| 日韩av电影国产| 精品中文字幕在线| 91av在线免费观看视频| 欧美视频中文在线看| 国产精品jvid在线观看蜜臀| 欧美重口另类videos人妖| 国产精品视频不卡| 7777kkkk成人观看| 2018日韩中文字幕| 97精品国产97久久久久久| 亚洲欧美在线一区二区| 欧美午夜视频一区二区| 在线视频免费一区二区| 国产精品pans私拍| 国产一区欧美二区三区| 91啪国产在线| 欧美亚洲成人网| 国模gogo一区二区大胆私拍| 久久69精品久久久久久久电影好| 欧美在线观看视频| 大伊人狠狠躁夜夜躁av一区| 国产精品私拍pans大尺度在线| 美女av一区二区三区| 亚洲人精选亚洲人成在线| 欧美夫妻性生活视频| 成人免费xxxxx在线观看| 精品久久久久国产| 欧美在线视频一区二区| 国产精品91久久久| 亚洲成人av中文字幕| 黄网站色欧美视频| 国产精品中文字幕久久久| 欧美另类99xxxxx| 亚洲欧美日韩另类| 国产精品三级久久久久久电影| 欧美麻豆久久久久久中文| 国产亚洲免费的视频看| 国产亚洲福利一区| 亚洲一区二区日本| 欧美性猛交xxxx乱大交蜜桃| 国产精品96久久久久久| 亚洲福利小视频| 91网站在线看| 国产精品日韩在线播放| 亚洲精品美女免费| 国产69精品久久久久9999| 欧美猛少妇色xxxxx| 丝袜美腿亚洲一区二区| 久久人人爽人人爽人人片av高请| 欧美激情2020午夜免费观看| 亚洲成色777777在线观看影院| 国产精品亚洲美女av网站| 精品女同一区二区三区在线播放| 成人激情视频免费在线| 国产精品日韩在线播放| 高清一区二区三区四区五区| 日韩成人在线播放| 国产在线观看91精品一区| 久久精品99久久香蕉国产色戒| 成人免费视频97| 国产精品视频在线观看| 亚洲性线免费观看视频成熟| 国产精品丝袜久久久久久高清| 欧美特黄级在线| 国产精品jvid在线观看蜜臀| 亚洲成色777777在线观看影院| 久久av在线看| 欧美成人剧情片在线观看| 久久福利视频导航| 亚洲精品国产精品国自产观看浪潮| 伊人男人综合视频网| 国产精品观看在线亚洲人成网| 欧美老女人bb| 国产一区二区三区毛片| 中文在线资源观看视频网站免费不卡| 久久精品国产一区| 亚洲精品白浆高清久久久久久| 国产成人在线亚洲欧美| 亚洲一区亚洲二区| 久久久www成人免费精品张筱雨| 欧美日韩裸体免费视频| 日韩av在线免费播放| 96pao国产成视频永久免费| 色综合天天综合网国产成人网| 国内精品小视频| 欧美高清在线播放| 日韩在线视频网站| 亚洲男子天堂网| 国产一区深夜福利| 国产精品美女999| 中文在线资源观看视频网站免费不卡|