KEMBAR78
Queue Data Structures Guide | PDF | Queue (Abstract Data Type) | Theoretical Computer Science
100% found this document useful (1 vote)
533 views26 pages

Queue Data Structures Guide

This document discusses queues as a data structure. It defines queues as linear data structures used for temporary storage of data values where new elements are added at the rear and existing elements are deleted from the front, following a first-in, first-out principle. It describes array and linked representations of queues and different types of queues like circular queues, deques, and priority queues. It also outlines some common applications of queues.

Uploaded by

vishnu neupane
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
100% found this document useful (1 vote)
533 views26 pages

Queue Data Structures Guide

This document discusses queues as a data structure. It defines queues as linear data structures used for temporary storage of data values where new elements are added at the rear and existing elements are deleted from the front, following a first-in, first-out principle. It describes array and linked representations of queues and different types of queues like circular queues, deques, and priority queues. It also outlines some common applications of queues.

Uploaded by

vishnu neupane
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
You are on page 1/ 26

Contents

 Introduction
 Operations on queue
 Array representation of queues
 Linked representation of queues
 Types of queues
 Circular queues
 Deques
 Priority queues
 Application of queues
 References
DATA STRUCTURE

A data structure is a particular way of


organizing data in a computer so that it can
be used efficiently.

Different kind of data structure suits for the


different kind of applications.
Data Structure

Primitive DS Non-Primitive DS

Integer
Linear Non Linear
Float
Char Array
Tre
Pointer Linked list e
Graph
s Stack
Queue
• Queue is a linear data structure.
• It is used for temporary storage of data
values.
• A new element is added at one end called
rear end.
• The existing elements deleted from the
• other end called front
First-in-First-out end.
property. rear

34 12 53 61 9 23 42

front
Operations on Queue
1.Insertion :
Placing an item in a queue is called “insertion
or enqueue”, which is done at the end of the
queue called “rear”.

Fron
Rea t
r
2.Deletion :
Removing an item from a queue is called
“deletion or dequeue” , which is done at
the other end of the queue called “front”.

Fron
Rea t
r
Array Representation of Queues
A[0] A[1] A[2] A[3]
A[4]
12 9 7 18
QUEUE
front
rear

fron rea
12 9 7 18 r
t 14
9 7 18 14
Queue after insertion of a new element
front rear
Queue after deletion of an
element
Algorithm to insert an element in queue
STEP-1 IF REAR= MAX-1 INITIALL
write OVERFLOW Y REAR =
go to step 4 -1
FRONT =-1
[end of if]
STEP-2 if REAR = -1
set
FRONT=REAR= 0
else
STEP-3 set QUEUE
set [ REAR
REAR =] = NUM
STEP- EXITREAR+1
4
Algorithm to delete an element from queue
STEP-1 If FRONT = -1 or FRONT > REAR
write UNDERFLOW
Else
set VAL = QUEUE
[ FRONT ] set FRONT =
FRONT + 1
[end of if]
STEP-2 EXIT
Linked Representation of Queues
9 300 7 350 4 360 2 N Front = 290
Rear = 360
290 Front 300 350 360 rear
Linked queue

9 300 7 350 4 360 2 380 5 N


290 front 300 350 360 380 rear
Linked queue after inserting a
node
7 350 4 360 2 380 5 N
300 350 380
front 360 rear
Linked queue after deleting a
node
Algorithm to insert an element in queue
using linked list
STEP-1 Allocate memory for the new node & name it as TEMP.
STEP-2 set TEMP data = NUM
set TEMP link =
INITIALLY
STEP-3 If FRONT = NULL FRONT=NUL
FRONT = REAR = L
TEMP REAR=NULL
Else
REAR link =
TEMP REAR =
STEP-4 TEMP
[ end of if]
EXIT
Algorithm to delete an element from queue
STEP-1 If FRONT = NULL
write underflow
go to step 3.
[end of if]
STEP-2 set TEMP
= FRONT FRONT = FRONT link
if FRONT =
NULL REAR
STEP-3 = NULL
EXIT
Types of Queues

1. Deque

2. Circular Queue

3. Priority Queue
DEQUES
1.Deque stands for double ended
queue. 2.Elements can be inserted or
deleted at either end.
3. Also known as head-tail linked list.

insertion insertion

34 12 53 61 9
fron rea
t deletion r deletion
Types Of Deque
insertion
1.Input restricted deque:
34 12 53 61 9
fron rea
t deletion r deletion

2. Output restricted
deque: insertion
insertion
34 12 53 61 9
fron rea
t deletion r
CIRCULAR QUEUES

•Circular queue are used to remove the


drawback of simple queue.

•Both the front and the rear pointers wrap


around to the beginning of the array.

•It is also called as “Ring buffer”.


Algorithm to insert an element in queue

INITIALLY
FRONT= -1
REAR= 0
Algorithm to delete an element from queue

STEP-1 If FRONT =NULL


write
UNDERFLOW go to
step 3
STEP-2 SET
[ endITEM=CQUEUE[FRONT]
of if ]
STEP-3 IF FRONT=REAR THEN(ONLY ONE ELEMENT)
SETFRONT=NULL & REAR=NULL

ELSE IF FRONT=N THEN SET FRONT=1


ELSE
SET FRONT=FRONT+1
PRIORITY
QUEUE
1.It is collection of elements where elements
are stored according to the their priority
levels.
2.Inserting and removing of elements from
queue is decided by the priority of the
elements.
3.An element of the higher priority is processed
first.
4.Two element of same priority are processed on
first-come-first-served basis.
Example: Suppose you have a few assignment from
different subjects. Which assignment will you want
to do first?

subjects Due date priority


DSGT 15 OCT 4
DLD 6 OCT 2
CYB 4 OCT 1
DS 8 OCT 3
APPLICATIONS
 Real world applications
 Cashier line in any store.
 Waiting on hold for tech support.
 people on an escalator.
 Checkout at any book store.
Applications related to computer science:

1. When data is transferred asynchronously between


two processes. eg. IO Buffers.
2.When a resource is shared among multiple
consumers. Examples include CPU scheduling,
Disk Scheduling.
3. In recognizing palindrome.
4. In shared resources management.
5.Keyboard buffer.
6.Round robin scheduling.
7.Job scheduling.
8.Simulation

You might also like