81、【栈与队列】leetcode ——232. 用栈实现队列(C++/Python版本)

题目描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

原题链接:232. 用栈实现队列

使用两个对顶栈实现

image.png
因为只能用栈的后进先出的方式实现队列先进先出的方式,因此就使用两个栈来实现。

一个stack用于输入元素,另一个stack用于输出元素。

每次先输入的会被压入到stack-in的栈底,当想要实现队列的方式输出时,需要让stack-in的栈底元素输出。因此就再用另一个stack-out作为媒介,将stack-in中元素全部压入stack-out中,此时stack-in中的栈底元素,就变成了stack-out中的栈顶元素。此时输出stack-out中元素时,先被输出的便是stack-in中的栈底元素。从而实现了队里的FIFO操作方式。

C++版本

class MyQueue {
public:
    stack<int> sIn;
    stack<int> sOut;
    MyQueue() {
        
    }
    
    void push(int x) {
        sIn.push(x);        
    }
    
    int pop() {        
        // 当sOut里为空时,将sIn中元素都加入压入进去
        if(sOut.empty()) {
            while(!sIn.empty()) {
                sOut.push(sIn.top());
                sIn.pop();
            }
        }
        // 当sOut里不为空时,获取sOut的栈顶元素弹出
        int res = sOut.top();
        sOut.pop();
        return res;
    }
    
    int peek() {
        // 复用已定义过的pop()方法
        int res = this->pop();
        // 因为为获取队头元素,而不弹出,因此需要压回栈中
        sOut.push(res);
        return res;
    }
    
    bool empty() {
        return sOut.empty() && sIn.empty();
    }
};

/**
 * Your MyQueue object will be instantiated and called as such:
 * MyQueue* obj = new MyQueue();
 * obj->push(x);
 * int param_2 = obj->pop();
 * int param_3 = obj->peek();
 * bool param_4 = obj->empty();
 */

Python版本

class MyQueue:

    def __init__(self):
        self.sIn = []
        self.sOut = []

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

    def pop(self) -> int:
        if not self.sOut:
            while self.sIn:
                self.sOut.append(self.sIn.pop())
        return self.sOut.pop()

    def peek(self) -> int:
        res = self.pop()
        self.sOut.append(res)
        return res

    def empty(self) -> bool:
        return not self.sOut and not self.sIn


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

image.png

参考文章:232.用栈实现队列用栈实现队列

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

辰阳星宇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值