leet-code/src/main/java/leetcode/editor/cn/ImplementQueueUsingStacks.java
2021-04-29 23:21:52 +08:00

135 lines
3.3 KiB
Java
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

//请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作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双端队列来模拟一个栈只要是标准的栈操作即可。
//
//
//
//
// 进阶:
//
//
// 你能否实现每个操作均摊时间复杂度为 O(1) 的队列?换句话说,执行 n 个操作的总时间复杂度为 O(n) ,即使其中一个操作可能花费较长时间。
//
//
//
//
// 示例:
//
//
//输入:
//["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 操作)
//
// Related Topics 栈 设计
// 👍 377 👎 0
package leetcode.editor.cn;
import java.util.Stack;
//232:用栈实现队列
public class ImplementQueueUsingStacks {
public static void main(String[] args) {
//测试代码
// Solution solution = new ImplementQueueUsingStacks().new Solution();
}
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class MyQueue {
Stack<Integer> stack1;
Stack<Integer> stack2;
/**
* Initialize your data structure here.
*/
public MyQueue() {
stack1 = new Stack<>();
stack2 = new Stack<>();
}
/**
* Push element x to the back of queue.
*/
public void push(int x) {
while (!stack1.empty()){
stack2.push(stack1.pop());
}
stack1.push(x);
while (!stack2.isEmpty()){
stack1.push(stack2.pop());
}
}
/**
* Removes the element from in front of queue and returns that element.
*/
public int pop() {
return stack1.pop();
}
/**
* Get the front element.
*/
public int peek() {
return stack1.peek();
}
/**
* Returns whether the queue is empty.
*/
public boolean empty() {
return stack1.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();
* boolean param_4 = obj.empty();
*/
//leetcode submit region end(Prohibit modification and deletion)
}