栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

Python 匹配括号

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Python 匹配括号

方法一:运用键值对方法

def isValid(s):
        symbol = {')':'(',']':'[','}':'{'}
        Save = []
        for i in s:
            if Save and i in symbol :
                if Save[-1] == symbol[i]: 
                  Save.pop()
                else:
                  return False
            else: 
              Save.append(i)
        return not Save
print(isValid(input()))

方法二:运用双向队列

mport sys
from collections import deque


def isValid(s):
    st = deque()  # 定义一个栈
    i = 0
    while i < len(s):
        e = s[i]
        if e == '(' or e == '[' or e == '{':
            st.append(e)  # 将左括号进栈
        else:
            if e == ')':
                if len(st) == 0 or st[-1] != '(':
                    return False  # 栈空或栈顶不是'('返回假
                st.pop()
            if e == ']':
                if len(st) == 0 or st[-1] != '[':
                    return False  # 栈空或栈顶不是'['返回假
                st.pop()
            if e == '}':
                if len(st) == 0 or st[-1] != '{':
                    return False  # 栈空或栈顶不是'{'返回假
                st.pop()
        i += 1
    return len(st) == 0


if __name__ == '__main__':
    
    s = sys.stdin.readline()
    print(isValid(s))

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/587728.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号