22
33https://leetcode-cn.com/problems/implement-stack-using-queues/
44
5- ## 思路
5+ > 用队列实现栈还是有点别扭。
6+
7+ # 225. 用队列实现栈
8+
9+ 使用队列实现栈的下列操作:
10+
11+ * push(x) -- 元素 x 入栈
12+ * pop() -- 移除栈顶元素
13+ * top() -- 获取栈顶元素
14+ * empty() -- 返回栈是否为空
15+
16+ 注意:
17+
18+ * 你只能使用队列的基本操作-- 也就是 push to back, peek/pop from front, size, 和 is empty 这些操作是合法的。
19+ * 你所使用的语言也许不支持队列。 你可以使用 list 或者 deque(双端队列)来模拟一个队列 , 只要是标准的队列操作即可。
20+ * 你可以假设所有操作都是有效的(例如, 对一个空的栈不会调用 pop 或者 top 操作)。
21+
22+
23+ # 思路
624
725有的同学可能疑惑这种题目有什么实际工程意义,** 其实很多算法题目主要是对知识点的考察和教学意义远大于其工程实践的意义,所以面试题也是这样!**
826
9- 相信做过 [ 0232.用栈实现队列 ] ( https://github. com/youngyangyang04/leetcode/blob/master/problems/0232.用栈实现队列.md ) 这道题目的部分同学会依然想着用一个输入队列 ,一个输出队列,就可以模拟栈的功能,其实不是这样的。
27+ 刚刚做过 [ 栈与队列:我用栈来实现队列怎么样? ] ( https://mp.weixin.qq. com/s/P6tupDwRFi6Ay-L7DT4NVg ) 的同学可能依然想着用一个输入队列 ,一个输出队列,就可以模拟栈的功能,仔细想一下还真不行!
1028
11- 队列是先进先出的规则,你把一个队列中的数据导入另一个队列中 ,数据的顺序并没有变,并有变成先进后出的顺序。
29+ ** 队列是先进先出的规则,把一个队列中的数据导入另一个队列中 ,数据的顺序并没有变,并有变成先进后出的顺序。**
1230
1331所以用栈实现队列, 和用队列实现栈的思路还是不一样的,这取决于这两个数据结构的性质。
1432
33+ 但是依然还是要用两个队列来模拟栈,只不过没有输入和输出的关系,而是另一个队列完全用又来备份的!
34+
1535如下面动画所示,** 用两个队列que1和que2实现队列的功能,que2其实完全就是一个备份的作用** ,把que1最后面的元素以外的元素都备份到que2,然后弹出最后面的元素,再把其他元素从que2导回que1。
1636
17- 模拟的队列执行语句如下:
18- queue.push(1);
19- queue.push(2);
37+ 模拟的队列执行语句如下:
38+ queue.push(1);
39+ queue.push(2);
40+ queue.pop(); // 注意弹出的操作
41+ queue.push(3);
42+ queue.push(4);
43+ queue.pop(); // 注意弹出的操作
44+ queue.pop();
2045queue.pop();
21- queue.push(3);
22- queue.push(4);
23- queue.pop();
24- queue.pop();
25- queue.pop();
26- queue.empty();
46+ queue.empty();
2747
2848<video src =' ../video/225.用队列实现栈.mp4 ' controls =' controls ' width =' 640 ' height =' 320 ' autoplay =' autoplay ' > Your browser does not support the video tag.</video ></div >
2949
3050详细如代码注释所示:
3151
32- ## C++代码
52+ # C++代码
3353
3454```
3555class MyStack {
3656public:
3757 queue<int> que1;
38- queue<int> que2; // 辅助队列
58+ queue<int> que2; // 辅助队列,用来备份
3959 /** Initialize your data structure here. */
4060 MyStack() {
4161
@@ -55,10 +75,10 @@ public:
5575 que1.pop();
5676 }
5777
58- int result = que1.front(); // 留下的最后一个元素就是我们要返回的值
78+ int result = que1.front(); // 留下的最后一个元素就是要返回的值
5979 que1.pop();
60- que1 = que2; // 再将que2赋值给que1
61- while(!que2.empty()) { // 清空que2
80+ que1 = que2; // 再将que2赋值给que1
81+ while (!que2.empty()) { // 清空que2
6282 que2.pop();
6383 }
6484 return result;
0 commit comments