C++解LeetCode225. 用队列实现栈(适合基础薄弱)

简介: 请你仅使用两个队列实现一个后入先出(LIFO)的栈,并支持普通栈的全部四种操作(push、top、pop 和 empty)。实现 MyStack 类:void push(int x) 将元素 x 压入栈顶。int pop() 移除并返回栈顶元素。int top() 返回栈顶元素。boolean empty() 如果栈是空的,返回 true ;否则,返回 false 。

请你仅使用两个队列实现一个后入先出(LIFO)的栈,并支持普通栈的全部四种操作(push、top、pop 和 empty)。


实现 MyStack 类:


void push(int x) 将元素 x 压入栈顶。

int pop() 移除并返回栈顶元素。

int top() 返回栈顶元素。

boolean empty() 如果栈是空的,返回 true ;否则,返回 false 。


注意:


你只能使用队列的基本操作 —— 也就是 push to back、peek/pop from front、size 和 is empty 这些操作。

你所使用的语言也许不支持队列。 你可以使用 list (列表)或者 deque(双端队列)来模拟一个队列 , 只要是标准的队列操作即可。


示例:


输入:

["MyStack", "push", "push", "top", "pop", "empty"]

[[], [1], [2], [], [], []]

输出:

[null, null, null, 2, 2, false]


解释:

MyStack myStack = new MyStack();

myStack.push(1);

myStack.push(2);

myStack.top(); // 返回 2

myStack.pop(); // 返回 2

myStack.empty(); // 返回 False


主要是push的操作不同

1、这个队列不能直接push进元素,因为栈最后放进去的元素是栈顶,而队列最后放进去的元素是尾

2、所以先把要插入的元素放进一个临时队列

3、把主队列的元素放进临时队列

4、最后让临时队列元素依次放进主队列



932366b18160437db68cbc2458db50e9.jpeg

class MyStack {
public:
    queue<int> queue1;
    queue<int> queue2;                //为临时的队列
    MyStack() {
    }
    void push(int x) {
       queue2.push(x);                 //把要插入的元素放进临时队列
       while(!queue1.empty()){         
           queue2.push(queue1.front());      //把第一个队列的头的值放到临时队列
           queue1.pop();             //弹出队列一的元素,最后弹出是防止队列头的元素丢失
       }
       while(!queue2.empty()){              //把临时队列元素归还给队列1
           queue1.push(queue2.front());      
           queue2.pop();
       }
    }
    int pop() {
        int x = queue1.front();             //存储栈顶元素的值
        queue1.pop();                       //完成出栈的操作
        return x;                          // 返回前栈顶元素的值
    }
    int top() {
        return queue1.front();
    }
    bool empty() {
        return queue1.empty();
    }
};


相关文章
|
1月前
|
C++
使用C++代码实现栈
使用C++代码实现栈
LeetCode 热题100——单调栈
LeetCode 热题100——单调栈
17 0
|
1月前
|
Go C++
【力扣】2696. 删除子串后的字符串最小长度(模拟 栈 C++ Go实现栈)
【2月更文挑战第18天】2696. 删除子串后的字符串最小长度(模拟 栈 C++ Go实现栈)
34 6
|
1月前
|
C++
两种解法解决 LeetCode 27. 移除元素【C++】
两种解法解决 LeetCode 27. 移除元素【C++】
|
7天前
|
算法 Java C语言
C++和Java中的随机函数你玩明白了吗?内附LeetCode470.rand7()爆改rand10()巨详细题解,带你打败LeetCode%99选手
C++和Java中的随机函数你玩明白了吗?内附LeetCode470.rand7()爆改rand10()巨详细题解,带你打败LeetCode%99选手
存储 编译器 Linux
13 0
|
23天前
|
存储 设计模式 算法
【C/C++ 数据结构 线性表】深入理解与实现栈:从基础到应用的全面探索
【C/C++ 数据结构 线性表】深入理解与实现栈:从基础到应用的全面探索
52 0
|
28天前
|
存储 程序员 编译器
【C/C++ 堆栈以及虚拟内存分段 】C/C++内存分布/管理:代码区、数据区、堆区、栈区和常量区的探索
【C/C++ 堆栈以及虚拟内存分段 】C/C++内存分布/管理:代码区、数据区、堆区、栈区和常量区的探索
27 0
|
30天前
|
安全 算法 调度
C++队列探秘:队列容器的使用技巧与实战案例解析
C++队列探秘:队列容器的使用技巧与实战案例解析
125 0
|
1月前
|
存储
leetcode1944. 队列中可以看到的人数
leetcode1944. 队列中可以看到的人数
16 0