Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
Skip to content

Commit 98d4f0b

Browse files
Update
1 parent 293fba4 commit 98d4f0b

File tree

2 files changed

+38
-17
lines changed

2 files changed

+38
-17
lines changed

README.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -58,6 +58,7 @@
5858
* [字符串:前缀表不右移,难道就写不出KMP了?](https://mp.weixin.qq.com/s/p3hXynQM2RRROK5c6X7xfw)
5959
* [字符串:总结篇!](https://mp.weixin.qq.com/s/gtycjyDtblmytvBRFlCZJg)
6060
* [栈与队列:来看看栈和队列不为人知的一面](https://mp.weixin.qq.com/s/VZRjOccyE09aE-MgLbCMjQ)
61+
* [栈与队列:我用栈来实现队列怎么样?](https://mp.weixin.qq.com/s/P6tupDwRFi6Ay-L7DT4NVg)
6162

6263
(持续更新中....)
6364

problems/0225.用队列实现栈.md

Lines changed: 37 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -2,40 +2,60 @@
22

33
https://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();
2045
queue.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
```
3555
class MyStack {
3656
public:
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

Comments
 (0)