当前位置:网站首页>LeetCode 232、用栈实现队列
LeetCode 232、用栈实现队列
2022-04-23 20:23:00 【亡于灬】
232、用栈实现队列
1)题目描述
请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(push
、pop
、peek
、empty
):
实现 MyQueue
类:
void push(int x)
将元素 x 推到队列的末尾int pop()
从队列的开头移除并返回元素int peek()
返回队列开头的元素boolean empty()
如果队列为空,返回true
;否则,返回false
说明:
- 你 只能 使用标准的栈操作 —— 也就是只有
push to top
,peek/pop from top
,size
, 和is empty
操作是合法的。 - 你所使用的语言也许不支持栈。你可以使用 list 或者 deque(双端队列)来模拟一个栈,只要是标准的栈操作即可。
示例 1:
输入:
["MyQueue", "push", "push", "peek", "pop", "empty"]
[[], [1], [2], [], [], []]
输出:
[null, null, null, 1, 1, false]
解释:
MyQueue myQueue = new MyQueue();
myQueue.push(1); // queue is: [1]
myQueue.push(2); // queue is: [1, 2] (leftmost is front of the queue)
myQueue.peek(); // return 1
myQueue.pop(); // return 1, queue is [2]
myQueue.empty(); // return false
提示:
1 <= x <= 9
- 最多调用
100
次push
、pop
、peek
和empty
- 假设所有操作都是有效的 (例如,一个空的队列不会调用
pop
或者peek
操作)
2)分析
由于栈是先进后出,队列是先进先出,可以使用两个栈来实现顺序的调换。
3)C++
代码
class MyQueue {
public:
stack<int> s1;
stack<int> s2;
MyQueue() {
}
void push(int x) {
s1.push(x);
}
int pop() {
if(s2.empty()){
while(!s1.empty()){
s2.push(s1.top());
s1.pop();
}
}
int res=s2.top();
s2.pop();
return res;
}
int peek() {
if(s2.empty()){
while(!s1.empty()){
s2.push(s1.top());
s1.pop();
}
}
int res=s2.top();
return res;
}
bool empty() {
return s1.empty()&&s2.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(); */
版权声明
本文为[亡于灬]所创,转载请带上原文链接,感谢
https://blog.csdn.net/qq_38342510/article/details/124360499
边栏推荐
- PIP installation package reports an error. Could not find a version that satisfies the requirement pymysql (from versions: none)
- Tencent Qiu Dongyang: techniques and ways of accelerating deep model reasoning
- Analysis of the relationship between generalized Bim and CAD under the current background
- 中金财富公司怎么样,开户安全吗
- The R language uses the timeroc package to calculate the multi time AUC value of survival data without competitive risk, and uses the confint function to calculate the confidence interval value of mul
- 2022 - Data Warehouse - [time dimension table] - year, week and holiday
- redis 分布式锁
- JDBC tool class jdbcfiledateutil uploads files and date format conversion, including the latest, simplest and easiest way to upload single files and multiple files
- WordPress插件:WP-China-Yes解决国内访问官网慢的方法
- Handwritten Google's first generation distributed computing framework MapReduce
猜你喜欢
The ODB model calculates the data and outputs it to excel
Livego + ffmpeg + RTMP + flvjs to realize live video
Building the tide, building the foundation and winning the future -- the successful holding of zdns Partner Conference
Commit and rollback in DCL of 16 MySQL
. Ren -- the intimate artifact in the field of vertical Recruitment!
堡垒机、跳板机JumpServer的搭建,以及使用,图文详细
Azkaban recompile, solve: could not connect to SMTP host: SMTP 163.com, port: 465 [January 10, 2022]
go-zero框架数据库方面避坑指南
BMP JPEG 图片转换为矢量图像 ContourTrace
Numpy - creation of data type and array
随机推荐
网络通信基础(局域网、广域网、IP地址、端口号、协议、封装、分用)
Cadence Orcad Capture CIS更换元器件之Link Database 功能介绍图文教程及视频演示
SQL Server connectors by thread pool 𞓜 instructions for dtsqlservertp plug-in
SQL Server Connectors By Thread Pool | DTSQLServerTP 插件使用说明
R language ggplot2 visual facet_wrap, and use the lineheight parameter to customize the height of the facet icon tab (gray label bar)
JDBC tool class jdbcconutil gets the connection to the database
【栈和队列专题】—— 滑动窗口
PCL点云处理之直线与平面的交点计算(五十三)
Sqoop imports data from Mysql to HDFS using lzop compression format and reports NullPointerException
go-zero框架数据库方面避坑指南
The ODB model calculates the data and outputs it to excel
上海回應“面粉官網是非法網站”:疏於運維被“黑”,警方已立案
Error reported by Azkaban: Azkaban jobExecutor. utils. process. ProcessFailureException: Process exited with code 127
Scripy tutorial - (2) write a simple crawler
ABAQUS script email auto notification
selenium.common.exceptions.WebDriverException: Message: ‘chromedriver‘ executable needs to be in PAT
What is the difference between a host and a server?
SQL Server Connectors By Thread Pool | DTSQLServerTP plugin instructions
[graph theory brush question-4] force deduction 778 Swimming in a rising pool
The R language uses the timeroc package to calculate the multi time AUC value of survival data without competitive risk, and uses the confint function to calculate the confidence interval value of mul