Queues and Stacks
by Jenny Chen, Eddie HuangTry Me
Introduction
Queues and stacks (quacks) are data structures for storing and querying elements in particular linear orders. Queues and stacks share a common interface:
push
- adds an element. (For queues, this is also known asenqueue
)pop
- queries/removes an element. (For queues, this is also known asdequeue
)
Queues
data:image/s3,"s3://crabby-images/f3719/f37195be7e24a69577f11d59293dd1bb24295b70" alt=""
Queues return elements in the order in which they were stored. We call this kind of data structure first-in-first-out (FIFO).
Stack
data:image/s3,"s3://crabby-images/f9ee0/f9ee0077d96d6bf2c74fce6ca4708c25f4ed9eef" alt=""
Stacks return elements in the reverse order in which they are stored; that is, the most recent element to be added is returned. We call this kind of data structure last-in-first-out (LIFO).
Implementations
Queues and stacks are often implemented with either linked lists or arrays.
Linked Lists
data:image/s3,"s3://crabby-images/d3160/d3160efd14da8948574b5b3ec27e7c0d5c47c875" alt=""
data:image/s3,"s3://crabby-images/2c7ef/2c7ef358fdc6e0ee09985e83679c46da69209a24" alt=""
data:image/s3,"s3://crabby-images/d8693/d869373b1d86002ac52a1a0f4ac0d72a82bcb632" alt=""
Arrays
When implementing queues and stacks with arrays, it's important to visualize them as "circular" arrays. The beginning and end of an array do not matter to a stack or a queue. Simply keep track of the indices that locate the front and back of the queue/stack. One of the limitations with this implementation is that it gives a limit to the amount of elements the data structure can store.
data:image/s3,"s3://crabby-images/f93d2/f93d25519c688c0f759292dc11e85cbbf17748ed" alt=""
data:image/s3,"s3://crabby-images/6ffef/6ffef0f60aa9b2f292af9b078504411fec041407" alt=""
data:image/s3,"s3://crabby-images/c693d/c693d9eec920d04ba7353ac902697fec1dbbe9b6" alt=""
data:image/s3,"s3://crabby-images/342df/342df087ade51d567dd41dd8f22fbc2e5341813c" alt=""