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/1987a/1987a821fb51df09a008616a9939ac203b62cd9a" 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/1519a/1519a4341dc0d7085131097f75288aea924554e5" 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/78f6b/78f6be92a52f4de40e59fc71db651ff896c8440b" alt=""
data:image/s3,"s3://crabby-images/48056/480563cfb5a494b2c11b1add9f9cd1806250cb56" alt=""
data:image/s3,"s3://crabby-images/65e4f/65e4f649c8a9a8a2075e175925c475ffe43b0a82" 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/fb2a0/fb2a06d39071ca9434e647ab6e86fba13f4365c3" alt=""
data:image/s3,"s3://crabby-images/5051f/5051f90776d0c58ba646acabc74832e458fafc89" alt=""
data:image/s3,"s3://crabby-images/53a29/53a29103c4fd853ca347ea8823645a3fb087f2ce" alt=""
data:image/s3,"s3://crabby-images/17ece/17ece29ccc36b8ada4a483660b307fbd197b6ef4" alt=""