DS 3

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 14

Module 3

Queues

A queue can be defined as an ordered list which enables insert operations to be


performed at one end called REAR and delete operations to be performed at
another end called FRONT. Queue is referred to be as First In First Out list. Queue is
the data structure that is similar to the queue in the real world.

Applications of Queue
 Queues can be used to schedule jobs and ensure that they are executed in the correct
order.
 Queues can be used to manage the order in which print jobs are sent to the printer.
 Queues are used to implement the breadth-first search algorithm.
 Queues can be used to manage incoming calls and ensure that they are handled in the
correct order.
 Queues can be used to manage the order in which processes are executed on the CPU.
 Queues can be used for buffering data while it is being transferred between two
systems. When data is received, it is added to the back of the queue, and when data is
sent, it is removed from the front of the queue.

Basic Operations of Queue Data Structure


 Enqueue (Insert): Adds an element to the rear of the queue.
 Dequeue (Delete): Removes and returns the element from the front of the queue.
 Peek: Returns the element at the front of the queue without removing it.
 isEmpty: Checks if the queue is empty.
 isFull: Checks if the queue is full.
Every queue includes two ends, FRONT and REAR, which indicate the position where deletion
and insertion can be performed. Initially, values of FRONT and REAR is set to -1.

Enqueue Operation

 Inserting a new element in the position REAR is called the enqueue operation.
We must check if the queue is full before insertion. After the enqueue operation
the REAR is incremented by 1 and will point to the newly inserted element.
 For inserting the first element in a queue, the value of FRONT has to be set to 0.
 Consider a queue of size 5. Suppose we have to insert A, B, C, D and E into the
queue. The following changes will be made to the queue.
Dequeue Operation

 Deleting an element in the position pointed by FRONT is called the dequeue


operation. We must check if the queue is empty before deletion. After the
dequeue operation, the FRONT is incremented by 1.
 After deleting the last element in a queue, the value of FRONT and REAR has to
be set to 0.
 Consider the following example where we dequeue elements one by one until the
queue becomes empty.
Representation of Queues
Queue is usually represented in the computer using a linear array or a one-way linked list.

Array Representation of Queue


A queue can be represented in a program by using a linear array of elements and three
pointer variables FRONT, REAR and MAX.The queue is empty if FRONT = REAR = -1.
The queue is full if FRONT =1 and REAR = MAX - 1.

The size of the above queue is 5. It has 3 elements A, B and C. The FRONT, REAR and
MAX pointers will have values 0, 2 and 5 respectively.The algorithms for enqueue and
dequeue operations are given below.

Algorithm: ENQUEUE(QUEUE, MAX, FRONT, REAR, ITEM)


Step 1: IF REAR = MAX-1
Write OVERFLOW
Goto step 4
[END OF IF]
Step 2: IF FRONT= -1 and REAR= -1
SET FRONT = REAR = 0
ELSE
SET REAR = REAR + 1
[END OF IF]
Step 3: SET QUEUE[REAR] = ITEM
Step 4: EXIT

 Print overflow and exit if the queue is full.


 For adding first element make FRONT = 0.
 Increment REAR by 1.
 Insert new element in the position pointed by REAR.

Algorithm DEQUEUE(QUEUE, MAX, FRONT, REAR, ITEM)


Step 1: IF FRONT = -1 OR FRONT > REAR
Write UNDERFLOW
ELSE
SET ITEM = QUEUE[FRONT]
SET FRONT = FRONT + 1
[END OF IF]
Step 2: EXIT

 Print underflow and exit if the queue is empty.


 Return the value pointed by FRONT.
 Increment FRONT by 1.
 Set FRONT = REAR = -1 for the last element.
Linked Representation of Queues

The disadvantage of using an array to represent a queue is that the array must be
specified to have a fixed size. If the array size cannot be known ahead of time, then the
linked representation is used.

The HEAD pointer of the linked list is used as the FRONT. Also, use another pointer
called REAR to store the address of the last element of the queue.

The algorithms for enqueue and dequeue operations are given below.

Algorithm: LINK_ENQUEUE
Step 1: Allocate memory for the new node and name it as PTR
Step 2: SET PTR -> DATA = VAL
Step 3: IF FRONT = NULL
SET FRONT = REAR = PTR
SET FRONT -> NEXT = REAR -> NEXT = NULL
ELSE
SET REAR -> NEXT = PTR
SET REAR = PTR
SET REAR -> NEXT = NULL
[END OF IF]
Step 4: END

Inserting an element in a linked queue

Algorithm: LINK_DEQUEUE
Step 1: IF FRONT = NULL
Write Underflow
Go to Step 5
[END OF IF]
Step 2: SET PTR = FRONT
Step 3: SET FRONT = FRONT -> NEXT
Step 4: FREE PTR
Step 5: END

Disadvantage of Queue
Look at the following queue.

You cannot insert a new value now, because the queue is completely full. Consider the
following case: two consecutive deletions are made.

Even though there is enough space to hold a new element, the overflow condition still occurs
since the condition REAR = MAX – 1 is still valid. This is a major drawback of a linear
queue. A solution to this problem is to make the queue circular.
Simple Queue or Linear Queue

In Linear Queue, an insertion takes place from one end while the deletion occurs from
another end. The end at which the insertion takes place is known as the rear end, and the end
at which the deletion takes place is known as front end. It strictly follows the FIFO rule.

The major drawback of using a linear Queue is that insertion is done only from the rear end.
If the first three elements are deleted from the Queue, we cannot insert more elements even
though the space is available in a Linear Queue. In this case, the linear Queue shows the
overflow condition as the rear is pointing to the last element of the Queue.

Circular Queue

In Circular Queue, all the nodes are represented as circular. It is similar to the linear Queue
except that the last element of the queue is connected to the first element. It is also known as
Ring Buffer, as all the ends are connected to another end.

The drawback that occurs in a linear queue is overcome by using the circular queue. If the
empty space is available in a circular queue, the new element can be added in an empty space
by simply incrementing the value of rear. The main advantage of using the circular queue is
better memory utilization.
Priority Queue

It is a special type of queue in which the elements are arranged based on the priority. It is a
special type of queue data structure in which every element has a priority associated with it.
Suppose some elements occur with the same priority, they will be arranged according to the
FIFO principle. The representation of priority queue is shown in the below image -

Insertion in priority queue takes place based on the arrival, while deletion in the priority
queue occurs based on the priority. Priority queue is mainly used to implement the CPU
scheduling algorithms.

There are two types of priority queue that are discussed as follows -

o Ascending priority queue - In ascending priority queue, elements can be inserted in


arbitrary order, but only smallest can be deleted first. Suppose an array with elements
7, 5, and 3 in the same order, so, insertion can be done with the same sequence, but
the order of deleting the elements is 3, 5, 7.
o Descending priority queue - In descending priority queue, elements can be inserted
in arbitrary order, but only the largest element can be deleted first. Suppose an array
with elements 7, 3, and 5 in the same order, so, insertion can be done with the same
sequence, but the order of deleting the elements is 7, 5, 3.

Deque (or, Double Ended Queue)

In Deque or Double Ended Queue, insertion and deletion can be done from both ends of the
queue either from the front or rear. It means that we can insert and delete elements from both
front and rear ends of the queue. Deque can be used as a palindrome checker means that if we
read the string from both ends, then the string would be the same.

Deque can be used both as stack and queue as it allows the insertion and deletion operations
on both ends. Deque can be considered as stack because stack follows the LIFO (Last In First
Out) principle in which insertion and deletion both can be performed only from one end. And
in deque, it is possible to perform both insertion and deletion from one end, and Deque does
not follow the FIFO principle.
There are two types of deque that are discussed as follows -

o Input restricted deque - As the name implies, in input restricted queue, insertion
operation can be performed at only one end, while deletion can be performed from
both ends.

o Output restricted deque - As the name implies, in output restricted queue, deletion
operation can be performed at only one end, while insertion can be performed from
both ends.

Tree
Tree data structure is a hierarchical structure that is used to represent and organize data in
a way that is easy to navigate and search. It is a collection of nodes that are connected by
edges and has a hierarchical relationship between the nodes .

The topmost node of the tree is called the root, and the nodes below it is called the child
nodes. Each node can have multiple child nodes, and these child nodes can also have their
own child nodes, forming a recursive structure .
Why Tree is considered a non-linear data structure?
The data in a tree are not stored in a sequential manner i.e., they are not stored linearly.
Instead, they are arranged on multiple levels or we can say it is a hierarchical structure. For
this reason, the tree is considered to be a non-linear data structure .

Basic Terminologies In Tree Data Structure:


 Parent Node: The node which is a predecessor of a node is called the parent node of
that node. {B} is the parent node of {D, E}.
 Child Node: The node which is the immediate successor of a node is called the child
node of that node. Examples: {D, E} are the child nodes of {B}.
 Root Node: The topmost node of a tree or the node which does not have any parent
node is called the root node. {A} is the root node of the tree. A non-empty tree must
contain exactly one root node and exactly one path from the root to all other nodes of
the tree.
 Leaf Node or External Node: The nodes which do not have any child nodes are called
leaf nodes. {K, L, M, N, O, P, G} are the leaf nodes of the tree.
 Ancestor of a Node: Any predecessor nodes on the path of the root to that node are
called Ancestors of that node. {A,B} are the ancestor nodes of the node {E}
 Descendant: A node x is a descendant of another node y if and only if y is an ancestor
of x.
 Sibling: Children of the same parent node are called siblings. {D,E} are called siblings.
 Level of a node: The count of edges on the path from the root node to that node. The
root node has level 0.
 Internal node: A node with at least one child is called Internal Node.
 Neighbour of a Node: Parent or child nodes of that node are called neighbours of that
node.
 Subtree: Any node of the tree along with its descendant.

Applications of Tree
 To search an element in a set quickly, Binary Search Trees(BSTs) are used.
 Heap sort is done by a kind of tree called Heap.
 Tries are modified version of trees used to store routing informations in routers.
 Compiler use a syntax tree to parse program you write.
 Shortest path trees and spanning Trees are used in bridges and routers.

Types of Tree data structures:

Tree data structure can be classified into three types based upon the number of children
each node of the tree can have. The types are:
 Binary tree: In a binary tree, each node can have a maximum of two children linked to
it.
 Ternary Tree: A Ternary Tree is a tree data structure in which each node has at most
three child nodes, usually distinguished as “left”, “mid” and “right”.
 N-ary Tree or Generic Tree : Generic trees are a collection of nodes where each node
is a data structure that consists of records and a list of references to its
children(duplicate references are not allowed). Unlike the linked list, each node stores
the address of multiple nodes.

Properties of Tree Data Structure:


 Number of edges: An edge can be defined as the connection between two nodes. If a
tree has N nodes then it will have (N-1) edges. There is only one path from each node to
any other node of the tree.
 Depth of a node: The depth of a node is defined as the length of the path from the root
to that node.
 Height of a node: The height of a node can be defined as the length of the longest path
from the node to a leaf node of the tree.
 Degree of a Node: The total count of subtrees attached to that node is called the degree
of the node. The degree of a leaf node must be 0. The degree of a tree is the maximum
degree of a node among all the nodes in the tree. The number of edges arriving at that
node is called the in-degree of a node. The number of edges leaving that node is the out-
degree of a node.

Binary Tree
The Binary tree means that the node can have maximum two children. Here, binary name
itself suggests that 'two'; therefore, each node can have either 0, 1 or 2 children. A non-empty
binary tree consist of the following:
 A node called the root node.
 A left sub-tree.
 A right sub-tree.
Both the sub-trees are themselves binary trees.

Types of Binary Tree

Balanced Binary Tree: A binary tree is balanced if the height difference between the left and
right subtrees of every node is at most 1. Balanced trees ensure optimal performance in
search operations.
Full Binary Tree: A full binary tree is a binary tree type where every node has either 0 or 2
child nodes.

Complete Binary Tree: A complete binary tree is a binary tree type where all the leaf nodes
must be on the same level. However, root and internal nodes in a complete binary tree can
either have 0, 1 or 2 child nodes.

Perfect Binary Tree: A perfect binary tree is a binary tree type where all the leaf nodes are
on the same level and every node except leaf nodes have 2 children.

Degenerate Binary Tree:A degenerate binary tree, also known as a pathological tree, is a
special type of binary tree where each parent node has only one child node. In other words, it
is a tree in which all the internal nodes have a degree of 1, and only the leaf nodes have a
degree of 0.
Degenerate binary trees can also be classified into two types
1. Left-skewed: A degenerate binary tree in which all the nodes lean towards the left
side of the tree.

2. Right-skewed: A degenerate binary tree in which all the nodes lean towards the right
side of the tree.

Representation of Binary Tree


Binary trees can be maintained in memory using either an array or a linked list.

Sequential representation of binary trees


The simplest technique for representing a binary tree is to store the elements using a
one-dimensional array. Suppose we are using a one-dimensional array TREE to store
the elements of a tree. The rules for a sequential binary tree are as follows:
 The root of the tree will be stored in TREE[0].
 If an element is stored in TREE[K], then
 It’s left child is stored in TREE[2K + 1].
 It’s right child is stored in TREE[2K + 2].
A tree of height h will require an array of maximum size 2h-1. A tree is empty if TREE[0] =
NULL.
The following figure shows a binary tree and its corresponding sequential representation.

Binary tree and its sequential representation


This method is inefficient unless the tree is (almost) full. Also, it is not possible to add a
new node if the tree is already full.
Linked representation of binary trees
Every node in a linked representation of binary tree will contain three parts:
 The data element.
 A pointer to the left node.
 A pointer to the right node.
It can be represented by a structure:

struct node {
struct node *left;
int data;
struct node *right;
};
The root node is pointed by a pointer ROOT. The tree is empty if ROOT = NULL

Linked representation of a binary tree

Common operations on binary tree


Insertion
Nodes can be inserted into binary trees in between two other nodes or added after a leaf node.
In binary trees, a node that is inserted is specified as to which child it is.Say that the external
node being added onto is node A. To add a new node after node A, A assigns the new node as
one of its children and the new node assigns node A as its parent
Deletion
Deletion is the process whereby a node is removed from the tree. Only certain nodes in a
binary tree can be removed unambiguously,
Node with zero or one children:The process of deleting an internal node in a binary tree Say
that the node to delete is node A. If a node has no children (external node), deletion is
accomplished by setting the child of A's parent to null. If it has one child, set the parent of A's
child to A's parent and set the child of A's parent to A's child.
Node with two children:In a binary tree, a node with two children cannot be deleted
unambiguously. However, in certain binary trees (including binary search trees) these nodes
can be deleted, though with a rearrangement of the tree structure.
TREE TRAVERSALS (Inorder, Preorder and Postorder)
Unlike linear data structures (Array, Linked List, Queues, Stacks, etc)
which have only one logical way to traverse them, trees can be traversed in different ways.

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy