当前位置:网站首页>leetcode 232. Implement Queue using Stacks
leetcode 232. Implement Queue using Stacks
2022-08-08 06:14:00 【okokabcd】
一、题目大意
标签: 栈和队列
https://leetcode.cn/problems/implement-queue-using-stacks
请你仅使用两个栈实现先入先出队列.队列应当支持一般队列支持的所有操作(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 操作)
进阶:
你能否实现每个操作均摊时间复杂度为 O(1) 的队列?换句话说,执行 n 个操作的总时间复杂度为 O(n) ,即使其中一个操作可能花费较长时间.
二、解题思路
用两个栈来实现一个队列:Because it needs to get the first-in, first-out result,So the array must be flipped through an extra stack.This flipping process can be done both while inserting,It can also be done while taking a value.
The following addresses the completion of the flipping process while inserting.
三、解题方法
3.1 Java实现
class MyQueue {
Stack<Integer> stackA;
Stack<Integer> stackB;
public MyQueue() {
stackA = new Stack<>();
stackB = new Stack<>();
}
public void push(int x) {
if (stackA.isEmpty()) {
stackA.push(x);
return;
}
while (!stackA.isEmpty()) {
stackB.push(stackA.pop());
}
stackB.push(x);
while (!stackB.isEmpty()) {
stackA.push(stackB.pop());
}
}
public int pop() {
return stackA.pop();
}
public int peek() {
return stackA.peek();
}
public boolean empty() {
return stackA.isEmpty();
}
}
四、总结小记
- 2022/8/7 Have a question on the weekend
边栏推荐
猜你喜欢
随机推荐
How many times the neural network is generally trained, the neural network training time is too long
The pta patching simple graph theory
28. Anomaly detection
请问学习MySQL应该安装哪个版本,现在哪个版本使用最多?
字符串哈希 哈希值
文件操作 - IO
MySQL5
gcc/g++使用
云计算和云服务,云计算
LVS:NAT模式详解
Unity鼠标光标使用学习
Session and cookie usage
cnn convolutional neural network backpropagation, convolutional neural network dimension change
【leetcode】剑指 Offer(专项突击版)汇总
【RPC】Mercury RPC
状态压缩复习
【matlab】matlab中变量赋值函数deal
数据库ADB多个字符,想要导入到ES存为nested的类型,这个支持吗?有对应的文档吗
查询跟踪多家快递单号,筛选某一时间发货的单号
Go-Excelize API source code reading (10) - SetActiveSheet(index int)









