代码随想录第十天 栈和队列

第一题 很经典的栈模拟队列 https://leetcode.cn/problems/implement-queue-using-stacks/submissions/693619507/

这道题倒是没啥算法性质,主要还是模拟(话说模拟也不简单啊,挺考验思维能力的),一个栈的话只能先进后出所以怎么都无法实现先进先出的效果,所以肯定是两个栈,一个模拟入队,一个模拟出队,具体实现时是一个栈作为压入栈,在压入数据时只往这个栈中压入,记为In_stack;另一个栈只作为弹出栈,在弹出数据时只从这个栈弹出,记为out_stack。因为数据压入栈的时候,顺序是先进后出的。那么只要把In_stack的数据再压入out_stack中,顺序就变回来了,这听上去简单但是有两个要注意:

  1. 一次性全部压入 :从 in_stackout_stack转移时,必须一次性转移所有元素。

  2. 非空不压入 :只要 out_stack 不为空,就绝对不能进行转移。

违反1的情况举例:1~5依次压入in_stackin_stack的栈顶到栈底为5~1,从in_stack压入out_stack 时,只将5和4压入了out_stackout_stack 还剩下1、2、3没有压入。此时如果用户想进行弹出操作,那么4将最先弹出,与预想的队列顺序就不一致。

违反2的情况举例:1~5依次压入in_stackin_stack将所有的数据压入out_stack ,此时从out_stack 的栈顶到栈底就变成了1~5。此时又有6~10依次压入in_stackout_stack 不为空,in_stack不能向其中压入数据。如果违反2压入了out_stack ,从out_stack 的栈顶到栈底就变成了6~10、1~5。那么此时如果用户想进行弹出操作,6将最先弹出,与预想的队列顺序就不一致.

python 复制代码
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:
        self._help()
        return self.out_stack.pop()

    def peek(self) -> int:
        self._help()
        return self.out_stack[-1]

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

    def _help(self):
        if not self.out_stack:
            with self.in_stack:
                self.out_stack.append(self.in_stack.pop())

def _help(self):

规则2:只有out_stack为空时才转移

if not self.out_stack:

规则1:一次性转移in_stack中的所有元素

while self.in_stack: # 这个while循环保证了"一次性全部"

self.out_stack.append(self.in_stack.pop())

相关推荐
大鹏说大话13 小时前
Java 锁膨胀机制深度解析:从偏向锁到重量级锁的进化之路
开发语言·c#
IT猿手13 小时前
基于 ZOH 离散化与增量 PID 的四旋翼无人机轨迹跟踪控制研究,MATLAB代码
开发语言·算法·matlab·无人机·动态路径规划·openclaw
IT猿手13 小时前
基于控制障碍函数(Control Barrier Function, CBF)的无人机编队三维动态避障路径规划,MATLAB代码
开发语言·matlab·无人机·动态路径规划·无人机编队
huaweichenai14 小时前
java的时间操作介绍
java·开发语言
就不掉头发14 小时前
C++右值与右值引用
开发语言·c++
SugarFreeOixi14 小时前
MATLAB绘图风格记录NP类型
python·matlab·numpy
IT猿手14 小时前
基于 CBF 的多无人机编队动态避障路径规划研究,无人机及障碍物数量可以自定义修改,MATLAB代码
开发语言·matlab·无人机·动态路径规划
炸膛坦客14 小时前
单片机/C/C++八股:(十六)C 中 malloc/free 和 C++ 中 new/delete 有什么区别?
c语言·开发语言·c++
@insist12314 小时前
软件设计师-组网技术基础:网络设备、传输介质与局域网核心协议
开发语言·网络·软考·软件设计师·软件水平考试
冥王丁B14 小时前
第31章 Prompt 与聊天模型笔记
笔记·python·prompt