Skip to content

Latest commit

 

History

History

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 

Queue

Queue is an abstract data structure, somewhat similar to Stacks. Unlike stacks, a queue is open at both its ends. One end is always used to insert data (enqueue) and the other is used to remove data (dequeue). Queue follows First-In-First-Out methodology, i.e., the data item stored first will be accessed first.

A real-world example of queue can be a single-lane one-way road, where the vehicle enters first, exits first. More real-world examples can be seen as queues at the ticket windows and bus-stops.

Queue

Basic Operations:

Queue operations may involve initializing or defining the queue, utilizing it, and then completely erasing it from the memory.. Apart from these basic stuffs, a queue is used for the following two primary operations −

  • enqueue() − add (store) an item to the queue.
  • dequeue() − remove (access) an item from the queue.

To use a queue efficiently, we need to check the status of queue as well. For the same purpose, the following functionality are available too −

  • peek() − get the first data element of the queue, without removing it.
  • isEmpty() − check if queue is empty.

Complexity Analysis

  • Insertion - O(1)
  • Deletion - O(1) (If implemented with array, then deletion will take O(n) for shifting elements to rearrange the Queue)
  • Access - O(n)
  • Search - O(n)

More on this topic