括号匹配算法

括号匹配算法用于检查一个字符串中的括号是否正确匹配,确保每个开括号都有相应的闭括号,并且它们的顺序是正确的。

例如

()

(()()())

上面这些都是正确的括号匹配

是栈这种数据结构的应用场景之一

复制代码
class Stack:
    def __init__(self):
        self.items = []

    def isEmpty(self):
        return len(self.items) == 0
        
    def push(self,item):
        self.items.append(item)
    
    def pop(self):
        return self.items.pop()

    def peek(self):
        return self.items[len(self.items) - 1]
    
    def size(self):
        return len(self.items)

实现这个算法需要使用栈这种数据结构,当然其实数组也是可以的。不过一般来说,这是最能体现栈这种数据结构特点的应用场景

具体实现

python 复制代码
def parChecker(symbolString):
    s = Stack()
    balanced = True
    index = 0
    while index < len(symbolString) and balanced:
        symbol = symbolString[index]
        if symbol == "(":
            s.push(symbol)
        else:
            if s.isEmpty():
                balanced = False
            else:
                s.pop()

        index = index + 1
    
    if balanced and s.isEmpty():
        return True
    else:
        return False
相关推荐
aini_lovee5 分钟前
C# 快速搜索磁盘文件解决方案
开发语言·c#
小陈工5 分钟前
2026年4月8日技术资讯洞察:边缘AI推理框架竞争白热化,Python后端开发者的机遇与挑战
开发语言·数据库·人工智能·python·微服务·回归
赵药师7 分钟前
YOLO中task.py改复杂的模块
python·深度学习·yolo
零二年的冬11 分钟前
epoll详解
java·linux·开发语言·c++·链表
大飞记Python17 分钟前
【2026更新】Python基础学习指南(AI版)——03内置函数
人工智能·python
凭君语未可17 分钟前
Java 中的接口是什么
java·开发语言
XiYang-DING18 分钟前
【Java】二叉树
java·开发语言·数据结构
断眉的派大星22 分钟前
pytorch中链式法则求解梯度
人工智能·pytorch·python
下北沢美食家28 分钟前
JavaScript面试题2
开发语言·javascript·ecmascript
疯狂成瘾者33 分钟前
text_splitter常见方法
python·langchain