括号匹配算法

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

例如

()

(()()())

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

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

复制代码
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
相关推荐
老前端的功夫4 分钟前
【Java从入门到入土】06:String的72变:从字符串拼接到底层优化
java·开发语言
程序猿(雷霆之王)6 分钟前
C++——AI大模型接入SDK
开发语言·c++
小付爱coding7 分钟前
openclaw源码架构深度解析【总体概况】
python·架构·openclaw
又是忙碌的一天10 分钟前
Java 面向对象三大特性:封装、继承、多态深度解析
java·前端·python
会编程的土豆15 分钟前
【从零学javase 第六天】网络编程(+多线程)
开发语言·网络·php
Yupureki20 分钟前
《C++实战项目-高并发内存池》8. 最终性能优化与测试
c语言·开发语言·数据结构·c++·算法·性能优化
隔壁小邓22 分钟前
在Java中实现优雅的CQRS架构
java·开发语言·架构
qq_3806513323 分钟前
xu#True
python
DeepModel26 分钟前
【概率分布】均匀分布的原理、推导与Python实现
python·算法·概率论
wmfglpz8829 分钟前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python