zoukankan      html  css  js  c++  java
  • python 经典面试题:判断字符串括号是否闭合{}[]()

    前言

    经典面试题: 判断一个字符串里面的括号是否闭合,如:{{()}} 就是一个闭合的字符串。
    {{()}]} 这个里面 ([)] 括号不对称,这种就是不闭合。

    python判断闭合

    解决基本思路:

    先把左括号添加到一个列表里面,遇到右括号就弹出列表里面的最后一个存放进去的。
    对比右括号和弹出的左括号是否对称,如果是就继续依次对比。

    最后判断列表里面是否有多余的左括号,如果列表为空,说明全部被弹出,那就是闭合的
    最后考虑下左括号和右括号有多余的情况

    def is_str_close(a):
        '''
        遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
        寻找有志同道合的小伙伴,互帮互助,群  里还有不错的视频学习教程和PDF电子书!
        判断括号是否闭合
        '''
        b = []
        flag = True
        for i in a:
            if i == "{" or i == "[" or i == "(":
                # 左边的括号加进去
                b.append(i)
            elif i == "}":
                # 遇到右边括号}弹出最后面的一个{
                if len(b) == 0 or b.pop() != "{":
                    return False
            elif i == "]":
                # 遇到右边括号]弹出最后面的一个[
                if len(b) == 0 or b.pop() != "[":
                    return False
            elif i == ")":
                # 遇到右边括号)弹出最后面的一个(
                if len(b) == 0 or b.pop() != "(":
                    return False
        # 判断最后列表b里面的左边括号是否全部被弹出
        if len(b) != 0:
            flag = False
        return flag
    
    if __name__ == '__main__':
        a = "{[{()}]()}"
        print(is_str_close(a))
        b = "({[{()}]()}"
        print(is_str_close(b))
        c = "{[{()}]()}]"
        print(is_str_close(c))
    

    PS:遇到问题没人解答?需要Python学习资料?可以加点击下方链接自行获取
    note.youdao.com/noteshare?id=2dce86d0c2588ae7c0a88bee34324d76

    运行结果

    True
    False
    False
    
  • 相关阅读:
    信息技术手册查重错误比对分析程序开发记录04
    信息技术手册查重错误比对分析程序开发记录03
    信息技术手册查重错误比对分析程序开发记录02
    第一周博客01——设计模式原则总结
    react 性能优化
    h5 rem js自动适配
    JavaScript深拷贝实现原理简析
    word,excel,ppt在线预览功能
    react-route4 学习记录
    README 语法记录
  • 原文地址:https://www.cnblogs.com/xxpythonxx/p/13669473.html
Copyright © 2011-2022 走看看