Lists: Using Stacks as Queues
Lists: Using Stacks as Queues
Stacks and queues might sound about as different as Hamilton and Burr, and…they are. Stacks are last in, first out (LIFO) structures, and queues are first in, first out (FIFO). Stacks insert and delete from the top, while queues insert in the back and delete from the front. If you replace one with the other, you'll get mass chaos—and probably a 19th Century duel or two.
At the same time, sometimes a stack has to talk less, smile more act like a queue to get things done.
You can totally make them act like each other if you set up a pair of stacks to mimic a queue. Sound bizarre and pointless? It is, but so is the idea of a hip-hop musical set during American Revolution. If it worked for Lin-Manuel Miranda, it can work for us, too.
At least for educational reasons, anyway.
To illustrate how this works, we'll compare a queue to the two stacks. Let's set everything up.
data:image/s3,"s3://crabby-images/f3cda/f3cda8cb38741a5f7a314fe6b23c8de8ca064f7f" alt="An empty Queue on the left, with Stack 1 in the middle and Stack 2 on the right."
In this queue, we'll work with letters instead of numbers just to shake things up. H is the first letter we'll enqueue, because it has some rocking symmetry. To mimic this enqueuing process with stacks, we'll push H onto Stack 1, too.
data:image/s3,"s3://crabby-images/60da9/60da9facd3e8fad9b12c09c716d0bf45b10cf0de" alt="Now both the Queue and Stack 1 have an H as the top/front element."
Since we threw a darts at an eye chart to get our letters, we'll enqueue (and push) the letters E and Q next. Now Stack 1 looks like that queue, except reversed.
data:image/s3,"s3://crabby-images/a1260/a12604904cd56f2073cc6e79bfdc7a0632184ddb" alt="A queue spelling HEQ, with Stack 1 beside it spelling QEH."
Whenever you want to dequeue a value, you're going to pretend like you're removing something from the bottom of the stack. To get rid of H, you'll need to pop both E and Q and move them to Stack 2 first, then pop the H that would be at the front of a queue.
data:image/s3,"s3://crabby-images/46fdf/46fdf3b0f4056c194704696e5e9ad39ec1a8ba36" alt="Queue is now just E and Q, while Stack 2 has E and Q and Stack 1 has the H that needs to be popped."
Then we'll pop H off of Stack 1.
data:image/s3,"s3://crabby-images/8ffc8/8ffc8901aae31fc0a4afca6f0cfdbb62d8c807cd" alt="Stack 1 is now empty."
Once that H is done for, you can pop everything back from Stack 2 and push it back to Stack 1.
data:image/s3,"s3://crabby-images/5e0b0/5e0b078e2eb4a9a7fbcbbc5f1a9b25de510e18f8" alt="Stack 2 is now empty, and Stack 1 has Q and E in the same order it did before."
Adding on is essentially the same when adding onto a queue as a stack. You don't need to do any fancy maneuvers to make them work. Dequeueing is the only place you need to change things up for stacks to work as queues.
Using two stacks takes a bit longer and involves more steps than just using a queue, but they can both get you to the same place.
It's kind-of a big deal.