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/18810/1881022bc32d4da628b8a255c233e89fcb332536" 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/4161f/4161f615cbf69d7ab5c3fe5d626f476699617be3" 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/85865/85865a7b81daf8b8f3e1beca1ebbb6c28bc26807" alt=""
data:image/s3,"s3://crabby-images/6d95c/6d95c014ec248d42b5d0d369acb2fe2509b45162" alt=""
data:image/s3,"s3://crabby-images/7320a/7320a811315bb6d9fa9f84b981a6e2ab62e74bf4" 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/970b0/970b05c4358ebecf650a062fe1c1e88b5faab2c4" alt=""
data:image/s3,"s3://crabby-images/e86a1/e86a19ec86512b1fd94ffc86e606b5ffaa18aa6a" alt=""
data:image/s3,"s3://crabby-images/d7c16/d7c169adee343a981c9ddfc22a4705eeadd0b91a" alt=""
data:image/s3,"s3://crabby-images/00f09/00f097c3c25252f20cc01d112582bb02baf696c0" alt=""