括号匹配算法

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

例如

()

(()()())

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

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

复制代码
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
相关推荐
xiaoshuaishuai8几秒前
C# CDN加速与离线包优化PowerSetting慢问题
开发语言·windows·spring·c#
凉辰10 分钟前
解决 H5 键盘遮挡与页面上推
开发语言·javascript·计算机外设
消晨消晨14 分钟前
MONAI初上手——模型构建
pytorch·python·monai
weixin_4440129318 分钟前
如何在多实例管理时隐藏MySQL版本信息_安全混淆与配置
jvm·数据库·python
weixin_4597539428 分钟前
SQL处理大规模分组聚合的内存限制_调整服务器配置
jvm·数据库·python
计算机安禾44 分钟前
【c++面向对象编程】第25篇:仿函数(函数对象):重载operator()
开发语言·c++·算法
Rust语言中文社区1 小时前
【Rust日报】2026-05-14 Pyrefly v1.0 正式发布:快速的 Python 类型检查器和语言服务器
开发语言·后端·python·rust
2601_956139421 小时前
广州VI设计公司哪家强
linux·运维·服务器·python
kkeeper~1 小时前
0基础C语言积跬步之深入理解指针(4)
c语言·开发语言
databook1 小时前
让数学公式自动推导
python·数学·动效