leetcode-用栈实现队列

232. 用栈实现队列

前面有道题是用队列实现栈 ,本题反过来了,是使用两个栈来模拟队列。

题解:

我们定义两个栈一个进栈in_stack,一个出栈out_stack,在push数据的时候将数据放入进栈就好,但在pop的时候,先要判断出栈是否为空,若为空的话,就把进栈的数据全部导入进来,再从出栈弹出数据,若出栈不为空,则直接从出栈弹出数据即可。判断进栈和出栈都为空,说明队列为空了

class MyQueue:

    def __init__(self):
        self.in_stack = []
        self.out_stack = []


    def push(self, x: int) -> None:
        self.in_stack.append(x)


    def pop(self) -> int:
        if self.empty():
            return None
        if self.out_stack:
            return self.out_stack.pop()
        else:
            for _ in range(len(self.in_stack)):
                self.out_stack.append(self.in_stack.pop())
            return self.out_stack.pop()


    def peek(self) -> int:
        top = self.pop()
        self.out_stack.append(top)
        return top


    def empty(self) -> bool:
        return not(self.in_stack or self.out_stack)

相关推荐

  1. leetcode-队列实现

    2024-02-03 19:04:01       36 阅读
  2. leetcode-实现队列

    2024-02-03 19:04:01       30 阅读
  3. LeetCode-232. 实现队列 设计 队列

    2024-02-03 19:04:01       31 阅读
  4. LeetCode255.队列实现

    2024-02-03 19:04:01       32 阅读
  5. LeetCode232:实现队列

    2024-02-03 19:04:01       18 阅读
  6. Leetcode225_队列实现

    2024-02-03 19:04:01       18 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-03 19:04:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-03 19:04:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-03 19:04:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-03 19:04:01       18 阅读

热门阅读

  1. Unity DOTween插件常用方法(一)

    2024-02-03 19:04:01       29 阅读
  2. MySQL进阶之触发器

    2024-02-03 19:04:01       26 阅读
  3. mysql b+搜索的算法次数的计算

    2024-02-03 19:04:01       29 阅读
  4. vscode 突然连接不上服务器了

    2024-02-03 19:04:01       30 阅读
  5. 积分、权益、卡卷 三者的理解

    2024-02-03 19:04:01       30 阅读
  6. 如何用Pycharm在本地调用chatgpt的接口

    2024-02-03 19:04:01       32 阅读
  7. eCos flash模拟EEPROM实现NV系统

    2024-02-03 19:04:01       27 阅读