使用两个栈实现一个队列

博客1
博客2

预备知识

  1. 栈是先进后出,在栈顶进出元素
  2. 队列是先进先出,队尾入队,队头出队
  3. 入队:元素直接入栈1
  4. 出队:先将栈1的元素依次出栈插入栈2,然后栈2出栈

在这里插入图片描述

# -*- coding:utf-8 -*-
class Solution:
    def __init__(self):
        self.stack1 = [] 
        self.stack2 = []
    def push(self, node):
       
        self.stack1.append(node) #直接入栈1
    def pop(self):
        # return xx
        '''
        如果栈2为空就代表没有进行过出队操作
        所以需要把栈1里面的元素全部压入栈2中,进行模拟队的出队操作
        '''
        if not self.stack2:
            while self.stack1:
                self.stack2.append(self.stack1.pop())
        '''
        如果栈2不为空就代表之前的操作已经使用过出队操作,直接取出栈2的栈顶
        元素就是当前出队的那个元素
        '''
        return self.stack2.pop()


实现思路

  1. 使用两个栈,栈1和栈2,栈1实现push操作,栈2实现pop操作
  2. 实现队列的push操作,将元素依次入栈
  3. 实现队列的pop操作
    1) 首先判断栈2是否为空
    若栈2为空,且栈1不为空:则将栈1的元素依次导入栈2,stack2.append(stack1.pop()),然后执行pop操作,将队头的元素删除
    若栈2为空,栈1为空:此时队列为空
    2)栈2不为空,直接进行stack2.pop操作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值