Data structure – Part 3 – Queue
data:image/s3,"s3://crabby-images/7c9a7/7c9a7646788fb2b0a16742fe5e0627c77cb94b65" alt="Data structure – Part 3 – Queue"
Queues, opposite of Stack data structure and one of the most useful data structures in problem-solving tasks.
A queue is an example of a first-in, first-out (FIFO) data structure. Queues are used to order processes submitted to an operating system or a print spooler, and simulation applications use queues to model scenarios such as customers standing in the line at a bank or a grocery store.
If you like structure documentation! Please go to my official Data-doc where you will find standard development documentation.
https://raufr.github.io/datadoc/#/Queues
Now let’s take a look at queue implementation in Javascript.
data:image/s3,"s3://crabby-images/97b40/97b4002e5abe350072c66bb1bba8e64eb253cbac" alt=""
The first thing we have to do, create a bunch of functions for different operations.
Implementing the Queue class using an array is straightforward. Using JavaScript arrays is an advantage many other programming languages don’t have because JavaScript contains a function for easily adding data to the end of an array, push(), and a function for easily removing data from the front of an array, shift().
Before move further, I highly recommend understanding the Array() data structure.
enqueue() and dequeue() functions are depend on push and shift function of array operation. Usually, add elements in a queue in the beginning or end. Very easy to implement. dataStore
is an empty array to holds all the elements.
data:image/s3,"s3://crabby-images/be34d/be34d8fc8a5b915c8c10d314e546eb152455578e" alt=""
front() and back() function are basically accessible function. Which will return the value of current queue elements.
data:image/s3,"s3://crabby-images/a3ae0/a3ae03f149f21e661c7f6b8536722af8f8172785" alt=""
Last two function we need, toString() and empty(). Provide checking functionality in a queue.
data:image/s3,"s3://crabby-images/ab410/ab41032ed97124129a0c14481eb68e1a795a9ba5" alt=""
We are done. Right now with the main function, our Queue HOF will look like.
data:image/s3,"s3://crabby-images/f62f9/f62f9d07ac8b68ed1e85801cd4649ed2d9293368" alt=""
What should we do now 😉
We will test the functionality of our fresh queue.
data:image/s3,"s3://crabby-images/073ed/073ed27c56eeb381ab91790ce15058835e1fe848" alt=""
That’s it. In the next article, we will discuss some real-world use case with queue data structure