2025.09.05 用队列实现栈 & 有效的括号 & 删除字符串中的所有相邻重复项

225. 用队列实现栈 - 力扣(LeetCode)

关键在于入栈,q1作为存储队列,q2作为压栈操作队列,先将元素压入q2,再按顺序将q1的元素转移到q2,同时交换q1,q2 的引用。

python 复制代码
class MyStack:

    def __init__(self):
        self.q1 = deque()
        self.q2 = deque()

    def push(self, x: int) -> None:
        self.q2.append(x)
        while self.q1 :
            self.q2.append(self.q1.popleft())
        self.q1, self.q2 = self.q2, self.q1

    def pop(self) -> int:
        return self.q1.popleft()

    def top(self) -> int:
        return self.q1[0]

    def empty(self) -> bool:
        return len(self.q1) == 0


# Your MyStack object will be instantiated and called as such:
# obj = MyStack()
# obj.push(x)
# param_2 = obj.pop()
# param_3 = obj.top()
# param_4 = obj.empty()

deque和queue的区别:

  1. queue是多线程安全的,deque不是

  2. queue的效率比较慢,操作只能是先进先出

  3. deque在单线程中效率高,有多样的操作(在两端进行添加(append()appendleft()) 和删除 (pop()popleft()) 操作时,时间复杂度为 O(1)

20. 有效的括号 - 力扣(LeetCode)

用栈的方式判断括号是否合法。

python 复制代码
class Solution:
    def isValid(self, s: str) -> bool:
        stack = []
        for x in s:
            if x == '(' or x == '[' or x == '{':
                stack.append(x)
            else:
                if len(stack) == 0:
                    return False
                temp = stack.pop()
                if x == ')' and temp != '(':
                    return False
                if x == ']' and temp != '[':
                    return False
                if x == '}' and temp != '{':
                    return False    
        if not len(stack) == 0:
            return False
        return True

1047. 删除字符串中的所有相邻重复项 - 力扣(LeetCode)

python 复制代码
class Solution:
    def removeDuplicates(self, s: str) -> str:
        stack = []
        for char in s :
            if len(stack) == 0:
                stack.append(char)
                continue
            top_char = stack[-1]
            if  top_char == char:
                stack.pop()
            else:
                stack.append(char)
        return ''.join(stack)
相关推荐
rchmin4 分钟前
限流算法:令牌桶与漏桶详解
算法·限流
小北方城市网4 分钟前
第1课:架构设计核心认知|从0建立架构思维(架构系列入门课)
大数据·网络·数据结构·python·架构·数据库架构
leoufung11 分钟前
LeetCode 221:Maximal Square 动态规划详解
算法·leetcode·动态规划
黑符石13 分钟前
【论文研读】Madgwick 姿态滤波算法报告总结
人工智能·算法·机器学习·imu·惯性动捕·madgwick·姿态滤波
源代码•宸15 分钟前
Leetcode—39. 组合总和【中等】
经验分享·算法·leetcode·golang·sort·slices
好易学·数据结构16 分钟前
可视化图解算法77:零钱兑换(兑换零钱)
数据结构·算法·leetcode·动态规划·力扣·牛客网
我的offer在哪里21 分钟前
Hugging Face:让大模型触手可及的魔法工厂
人工智能·python·语言模型·开源·ai编程
AlenTech30 分钟前
226. 翻转二叉树 - 力扣(LeetCode)
算法·leetcode·职场和发展
Tisfy34 分钟前
LeetCode 1458.两个子序列的最大点积:动态规划
算法·leetcode·动态规划·题解·dp
求梦82034 分钟前
【力扣hot100题】合并区间(9)
算法·leetcode·职场和发展