括号匹配算法

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

例如

()

(()()())

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

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

复制代码
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
相关推荐
爱滑雪的码农几秒前
Java基础十三:Java中的继承、重写(Override)与重载(Overload)详解
java·开发语言
Java面试题总结2 分钟前
使用 Python 设置 Excel 数据验证
开发语言·python·excel
【 】4234 分钟前
C++&STL(Standard Template Library,标准模板库)
java·开发语言·c++
eastyuxiao11 分钟前
OpenClaw 自动处理核心逻辑
开发语言·人工智能
小郑加油11 分钟前
python学习Day10天:列表进阶 + 内置函数 + 代码简化
开发语言·python·学习
eastyuxiao20 分钟前
影响 OpenClaw 自动处理效率的核心因素
开发语言·人工智能
啧不应该啊30 分钟前
Day1 python与c宏观区别
c语言·开发语言
时空系30 分钟前
第13篇:综合实战——制作我的小游戏 python中文编程
开发语言·python·ai编程
XiYang-DING35 分钟前
【Java EE】CAS(Compare And Swap)
java·开发语言·java-ee
OneT1me39 分钟前
CVE-2026-31431 的C语言版本
c语言·开发语言·安全威胁分析