This article has been included at github.com/vipstone/al… Algorithmic diagrams series.
Queue and stack are two very important data structures in the computer, after the previous learning (” queue “, “stack”) we know their respective characteristics, queue is first in first out (FIFO), and the stack is first out (FILO), how to use stack to achieve queue? This is a classic interview question, so here’s how to do it.
Before we begin, let’s review the common approaches to stacks and queues.
Common methods of Stack include the following:
- Push () : a method that adds elements to the top of the stack;
- Pop () : unstack method that removes the top element and returns the element;
- Peek () : Queries the top of the stack without removing the element.
Common methods for queues include the following:
- Offer () : method of joining a team, adding elements to the end of the team;
- Poll () : exit method that removes and returns elements from the header;
- Peek () : Queries header elements and does not remove elements.
So with that in mind, let’s move on to today’s problem.
Topic describes
Implement a queue with two stacks. Insert an integer at the end of the queue (appendTail) and delete an integer at the head (deleteHead). If there are no elements in the queue, the deleteHead operation returns -1.
Example 1:
Input:
[“CQueue”,”appendTail”,”deleteHead”,”deleteHead”]
[[], [3], [], []]
Output: [null, null, 3-1]
Example 2:
Input:
[“CQueue”,”deleteHead”,”appendTail”,”appendTail”,”deleteHead”,”deleteHead”]
[[], [], [5], [2], [], []]
Output: [null, 1, null, null, 5, 2]
Tip:
1 <= values <= 10000
At most 10000 calls are made to appendTail and deleteHead
Leetcode:leetcode-cn.com/problems/yo…
Their thinking
A queue with two stacks is a queue with two stacks. A queue with two stacks is a queue with two stacks. This problem is to realize the core idea is “negative negative to positive”, we first use a stack to deposited in the element (the first to enter the element at the end of the stack), then the first element in the moving to the new stack, at this time the first to enter the element at the top of the stack, and then in the second out of the stack, the order of execution became the first in first out.
Next, let’s use a graphical way to implement the whole process.
Step one
The element is pushed onto the first stack, as shown below:
Step 2
Move all the elements in the first stack to the second stack, as shown below:
Step 3
All elements are pushed out of the second stack, as shown below:
summary
As you can see from the above picture, elements are added in order 1, 2, 3, and finally removed from the stack in order 1, 2, 3 after passing through two stacks, so we have a queue through two stacks (first-in, first-out).
The implementation code
Let’s use code to implement the above ideas:
class CQueue {
Stack<Integer> inputStack; // The container to be pushed (operation when adding)
Stack<Integer> outputStack; // Unstack and query the stack container
public CQueue(a) {
inputStack = new Stack();
outputStack = new Stack();
}
// Add operations
public void appendTail(int value) {
inputStack.push(value);
}
// Delete operation
public int deleteHead(a) {
if(! outputStack.isEmpty()) {// The stack container is not empty
return outputStack.pop();
} else if(! inputStack.isEmpty()) {// Move the stack stack to the stack stack
while (!inputStack.isEmpty()) {
outputStack.push(inputStack.pop());
}
}
return outputStack.isEmpty() ? -1: outputStack.pop(); }}Copy the code
We submitted the above test code in LeetCode and the result is as follows:
Matters needing attention
There are two small details that need special attention throughout the implementation:
- The first stack is only responsible for pushing (temporary data) and the second stack is only responsible for pushing (final queue execution order);
- New data can be added from stack 1 only after all the elements are removed from stack 2. If all the elements are not removed from stack 2, the elements of stack 1 cannot be added to stack 2, which will result in the element execution order disorder.
conclusion
Advanced in this paper, we through the two after the stack by the thinking of “negative negative to positive” the characteristics of the queue first in first out, but need to pay special attention to when the second is the stack container, in the empty (stack) can’t be the first element in the added to the second stack, lest cause the program execution chaos sequence.
Bonus: search the public account “Java Chinese Community” and send “interview” to receive the latest interview materials.