Quantom DSA
Quantom DSA
CONTENTS
Part-1 : Introduction : ............................................... 1–3A to 1–5A
Basic Terminology,
Elementary Data Organization
Built in Data Types in C
Questions-Answers
Que 1.1. Define data structure. Describe about its need and types.
Answer
Data structure :
1. A data structure is a way of organizing all data items that considers not
only the elements stored but also their relationship to each other.
2. Data structure is the representation of the logical relationship existing
between individual elements of data.
3. Data structure is define as a mathematical or logical model of particular
organization of data items.
Data structure is needed because :
1. It helps to understand the relationship of one element with the other.
2. It helps in the organization of all data items within the memory.
The data structures are divided into following categories :
1. Linear data structure :
a. A linear data structure is a data structure whose elements form a
sequence, and every element in the structure has a unique
predecessor and unique successor.
b. Examples of linear data structure are arrays, linked lists, stacks
and queues.
2. Non-linear data structure :
a. A non-linear data structure it is a data structure whose elements do not
form a sequence. There is no unique predecessor or unique successor.
b. Examples of non-linear data structures are trees and graphs.
Need of data type : The data type is needed because it determines what type
of information can be stored in the field and how the data can be formatted.
Que 1.2. Discuss some basic terminology used and elementary
data organization in data structures.
1–4 A (CS/IT-Sem-3) Array and Linked List
Answer
Basic terminologies used in data structure :
1. Data : Data are simply values or sets of values. A data item refers to a
single unit of values.
2. Entity : An entity is something that has certain attributes or properties
which may be assigned values.
3. Field : A field is a single elementary unit of information representing an
attribute of an entity.
4. Record : A record is the collection of field values of a given entity.
5. File : A file is the collection of records of the entities in a given entity set.
Data organization : Each record in a file may contain many field items, but
the value in a certain field may uniquely determine the record in the file.
Such a field K is called a primary key, and the values k1, k2,... in such a field
are called keys or key values.
Que 1.3. Define data types. What are built in data types in C ?
Explain.
Answer
1. C data types are defined as the data storage format that a variable can
store a data to perform a specific operation.
2. Data types are used to define a variable before to use in a program.
3. There are two types of built in data types in C :
a. Primitive data types : Primitive data types are classified as :
i. Integer type : Integers are used to store whole numbers.
Size and range of integer type on 16-bit machine :
Type Size (bytes) Range Format
specifier
int or signed int 2 – 32,768 to 32,767 %d
unsigned int 2 0 to 65,535 %u
short int or signed
short int 1 – 128 to 127 %hd
unsigned short int 1 0 to 255 %hu
long int or signed
long int 4 – 2,147,483,648 %ld
to 2,147,483,647
unsigned long int 4 0 to 4,294,967,295 %lu
ii. Floating point type : Floating types are used to store real numbers.
Data Structure 1–5 A (CS/IT-Sem-3)
iii. Character type : Character types are used to store characters value.
Size and range of character type on 16-bit machine :
Type Size (bytes) Range Format
specifier
char or signed char 1 – 128 to 127 %c
unsigned char 1 0 to 255 %c
iv. Void type : Void type is usually used to specify the type of functions
which returns nothing.
b. Non-primitive data types :
i. These are more sophisticated data types. These are derived from
the primitive data types.
ii. The non-primitive data types emphasize on structuring of a group
of homogeneous (same type) or heterogeneous (different type)
items. For example, arrays, lists and files.
Questions-Answers
Answer
1. An algorithm is a step-by-step finite sequence of instructions, to solve a
well-defined computational problem.
2. Every algorithm must satisfy the following criteria :
i. Input : There are zero or more quantities which are externally
supplied.
1–6 A (CS/IT-Sem-3) Array and Linked List
Answer
The efficiency of an algorithm can be checked by :
1. Correctness of an algorithm
2. Implementation of an algorithm
3. Simplicity of an algorithm
4. Execution time and memory requirements of an algorithm
Different ways of analyzing an algorithm :
a. Worst case running time :
1. The behaviour of an algorithm with respect to the worst possible
case of the input instance.
2. The worst case running time of an algorithm is an upper bound on
the running time for any input.
b. Average case running time :
1. The expected behaviour when the input is randomly drawn from a
given distribution.
2. The average case running time of an algorithm is an estimate of
the running time for an “average” input.
c. Best case running time :
1. The behaviour of the algorithm when input is already in order. For
example, in sorting, if elements are already sorted for a specific
algorithm.
2. The best case running time rarely occurs in practice comparatively
with the first and second case.
Que 1.6. Define complexity and its types.
Answer
1. The complexity of an algorithm M is the function f(n) which gives the
running time and/or storage space requirement of the algorithm in
terms of the size n of the input data.
Data Structure 1–7 A (CS/IT-Sem-3)
Answer
Complexity of an algorithm : Refer Q. 1.6, Page 1–6A, Unit-1.
Worst case complexity : (n) + (3n) = (n)
Answer
Complexity of an algorithm : Refer Q. 1.6, Page 1–6A, Unit-1.
Relation between the time and space complexities of an algorithm :
1. The time and space complexities are not related to each other.
2. They are used to describe how much space/time our algorithm takes
based on the input.
3. For example, when the algorithm has space complexity of :
1–8 A (CS/IT-Sem-3) Array and Linked List
a. O(1) i.e., constant then the algorithm uses a fixed (small) amount
of space which does not depend on the input. For every size of the
input the algorithm will take the same (constant) amount of space.
b. O(n), O(n2), O(log (n)) - these indicate that we create additional
objects based on the length of our input.
4. In contrast, the time complexity describes how much time our algorithm
consumes based on the length of the input.
5. For example, when the algorithm has time complexity of :
a. O(1) i.e., constant then no matter how big is the input it always
takes a constant time.
b. O(n), O(n2), O(log (n)) - again it is based on the length of the input.
For example :
function(list l) { function(list l) {
for (node in l) { print(“I got a list”); }
print(node) ;
}
}
In this example, both take O(1) space as we do not create additional
objects which shows that time and space complexity might be different.
Questions-Answers
Answer
1. Asymptotic notation is a shorthand way to describe running times for an
algorithm.
2. It is a line that stays within bounds.
3. These are also referred to as ‘best case’ and ‘worst case’ scenarios
respectively.
Big ‘Oh’ notation :
1. Big-Oh is formal method of expressing the upper bound of an algorithm’s
running time.
2. It is the measure of the longest amount of time it could possibly take for
the algorithm to complete.
3. More formally, for non-negative functions, f (n) and g(n), if there exists
an integer n0 and a constant c > 0 such that for all integers n > n0.
Data Structure 1–9 A (CS/IT-Sem-3)
f (n) cg(n)
4. Then, f (n) is Big-Oh of g (n). This is denoted as : f (n) O(g (n))
i.e., the set of functions which, as n gets large, grow faster than a
constant time f (n).
cg(n)
f(n)
f(n) = O(g(n))
n
n0
Fig. 1.9.1.
Answer
Complexity of an algorithm : Refer Q. 1.6, Page 1–6A, Unit-1.
Notations used to express the complexity of an algorithm :
1. -Notation (Same order) :
a. This notation bounds a function to within constant factors.
b. We say f(n) = g(n) if there exist positive constants n0, c1 and c2
such that to the right of n0 the value of f(n) always lies between
c1g(n) and c2g(n) inclusive.
c2g(n)
f(n)
c1g(n) f(n) = (g(n))
n
n0
Fig. 1.10.1.
2. Oh-Notation (Upper bound) : Refer Q. 1.9, Page 1–8A, Unit-1.
3. -Notation (Lower bound) :
a. This notation gives a lower bound for a function to within a constant
factor.
1–10 A (CS/IT-Sem-3) Array and Linked List
cg(n)
f(n) = (g(n))
n
n0
Fig. 1.10.2.
4. Little - Oh notation (o) :
a. It is used to denote an upper bound that is asymptotically tight
because upper bound provided by O-notation is not tight.
b. We write o(g(n)) = {f(n) : For any positive constant c > 0, if a
constant n0 > 0 such that 0 < f(n) < cg(n) V n > n0}
5. Little omega notation () :
a. It is used to denote lower bound that is asymptotically tight.
b. We write (g(n)) = {f(n) : For any positive constant c > 0, if a
constant n0 > 0 such that 0 < cg(n) < f(n)}
Questions-Answers
Answer
Time-space trade-off :
1. The time-space trade-off refers to a choice between algorithmic solutions
of data processing problems that allows to decrease the running time of
an algorithmic solution by increasing the space to store data and
vice-versa.
Data Structure 1–11 A (CS/IT-Sem-3)
Answer
Time-space trade-off : Refer Q. 1.11, Page 1–10A, Unit-1.
Best, worst and average case analysis : Suppose we are implementing
an algorithm that helps us to search for a record amongst a list of records. We
can have the following three cases which relate to the relative success our
algorithm can achieve with respect to time :
1. Best case :
a. The record we are trying to search is the first record of the list.
b. If f(n) is the function which gives the running time and / or storage
space requirement of the algorithm in terms of the size n of the
input data, this particular case of the algorithm will produce a
1–12 A (CS/IT-Sem-3) Array and Linked List
complexity C(n) = 1 for our algorithm f(n) as the algorithm will run
only 1 time until it finds the desired record.
2. Worst case :
a. The record we are trying to search is the last record of the list.
b. If f(n) is the function which gives the running time and / or storage
space requirement of the algorithm in terms of the size n of the
input data, this particular case of the algorithm will produce a
complexity C(n) = n for our algorithm f(n), as the algorithm will run
n times until it finds the desired record.
3. Average case :
a. The record we are trying to search can be any record in the list.
b. In this case, we do not know at which position it might be.
c. Hence, we take an average of all the possible times our algorithm
may run.
d. Hence assuming for n data, we have a probability of finding any
one of them is 1/n.
e. Multiplying each of these with the number of times our algorithm
might run for finding each of them and then taking a sum of all
those multiples, we can obtain the complexity C(n) for our algorithm
f(n) in case of an average case as following :
1 1 1
C(n) = 1· + 2· + ... + n·
2 2 2
1
C(n) = (1 + 2 + ... + n) ·
2
n(n 1) 1 n 1
C(n) = ·
2 n 2
Hence in this way, we can find the complexity of an algorithm for
average case as
C(n) = O((n + 1)/2)
Answer
1. An Abstract Data Type (ADT) is defined as a mathematical model of the
data objects that make up a data type as well as the functions that
operate on these objects.
2. An Abstract Data Type (ADT) is the specification of the data type which
specifies the logical and mathematical model of the data type.
3. It does not specify how data will be organized in memory and what
algorithm will be used for implementing the operations.
Data Structure 1–13 A (CS/IT-Sem-3)
Questions-Answers
Answer
1. An array can be defined as the collection of the sequential memory
locations, which can be referred to by a single name along with a number
known as the index, to access a particular field or data.
2. The general form of declaration is :
type variable-name [size];
a. Type specifies the type of the elements that will be contained in the
array, such as int, float or char and the size indicates the maximum
of elements that can be stored inside the array.
b. For example, when we want to store 10 integer values, then we can
use the following declaration, int A[10].
Que 1.15. Write short note on types of an array.
Answer
There are two types of array :
1. One-dimensional array :
a. An array that can be represented by only one-one dimension such
as row or column and that holds finite number of same type of data
items is called one-dimensional (linear) array.
b. One dimensional array (or linear array) is a set of ‘n’ finite numbers
of homogeneous data elements such as :
i. The elements of the array are referenced respectively by an
index set consisting of ‘n’ consecutive number.
1–14 A (CS/IT-Sem-3) Array and Linked List
Questions-Answers
Answer
1. In row major order, the element of an array is stored in computer
memory as row-by-row.
2. Under row major representation, the first row of the array occupies the
first set of memory locations reserved for the array, the second row
occupies the next set, and so forth.
3. In row major order, elements of a two-dimensional array are ordered
as :
A11, A12, A13, A14, A15, A16, A21, A22, A23, A24, A25, A26, A31, ....., A46, A51, A52,
......, A56
Example :
Let us consider the following two-dimensional array :
a b c d
e f g h
i j k l
Data Structure 1–15 A (CS/IT-Sem-3)
a. Move the elements of the second row starting from the first element
to the memory location adjacent to the last element of the first row.
b. When this step is applied to all the rows except for the first row, we
have a single row of elements. This is the row major representation.
c. By application of above mentioned process, we get
{a, b, c, d, e, f, g, h, i, j, k, l}
Que 1.17. Explain column major order with an example.
Answer
1. In column major order the elements of an array is stored as column-by-
column, it is called column major order.
2. Under column major representation, the first column of the array
occupies the first set of memory locations reserved for the array, the
second column occupies the next set, and so forth.
3. In column major order, elements are ordered as :
A11, A21, A31, A41, A51, A12, A22, A32, A42, A52, A13, ....., A55, A16, A26, ......., A56.
Example : Consider the following two-dimensional array :
a b c d
e f g h
i j k l
a. Transpose the elements of the array. Then, the representation will
be same as that of the row major representation.
b. Then perform the process of row-major representation.
c. By application of above mentioned process, we get
{a, e, i, b, f, j, c, g, k, d, h, l}.
Que 1.18. Write a short note on address calculation for 2D array.
OR
Determine addressing formula to find the location of (i, j)th element
of a m × n matrix stored in column major order.
OR
Derive the index formulae for 1-D and 2-D array.
Answer
1. Let us consider a two-dimensional array A of size m × n. Like linear
array system keeps track of the address of first element only, i.e., base
address of the array (Base (A)).
2. Using the base address, the computer computes the address of the
element in the ith row and jth column i.e., LOC (A[i][j]).
Formulae :
a. Column major order :
LOC(A[i][j]) = Base (A) + w[m(j – lower bound for column index)
1–16 A (CS/IT-Sem-3) Array and Linked List
Answer
In three-dimensional array, address is calculated using following two
methods :
Row major order :
Location (A[i, j, k]) = Base (A) + mn (k – 1) + n (i – 1) + (j – 1)
Column major order :
Location (A[i, j, k] ) = Base (A) + mn (k – 1) + m (j – 1) + (i – 1)
For example : Given an array [1..8, 1..5, 1..7] of integers. If Base (A) = 900
then address of element A[5, 3, 6], by using rows and columns methods are :
The dimensions of A are : M = 8, N = 5, R = 7, i = 5, j = 3, k = 6
Row major order :
Location (A[i, j, k]) = Base (A) + mn (k – 1) + n (i – 1) + (j – 1)
Location (A[5, 3, 6]) = 900 + 8 × 5(6 – 1) + 5(5 – 1) + (3 – 1)
= 900 + 40 × 5 + 5 × 4 + 2
= 900 + 200 + 20 + 2 = 1122
Column major order :
Location (A[i, j, k]) = Base (A) + mn (k – 1) + m (j – 1) + (i – 1)
Location (A[5, 3, 6]) = 900 + 8 × 5(6 – 1) + 8(3 – 1) + (5 – 1)
= 900 + 40 × 5 + 8 × 2 + 4
= 900 + 200 +16 + 4 = 1120
Que 1.20. Consider the linear arrays AAA [5 : 50], BBB [– 5 : 10] and
CCC [1 : 8].
a. Find the number of elements in each array.
b. Suppose base (AAA) = 300 and w = 4 words per memory cell for
AAA. Find the address of AAA [15], AAA [35] and AAA [55].
AKTU 2015-16, Marks 10
Answer
a. The number of elements is equal to the length; hence use the formula :
Data Structure 1–17 A (CS/IT-Sem-3)
Length = UB – LB + 1
Length (AAA) = 50 – 5 + 1 = 46
Length (BBB) = 10 – (– 5) + 1 = 16
Length (CCC) = 8 – 1 + 1 = 8
b. Use the formula
LOC (AAA [i]) = Base (AAA) + w (i – LB)
LOC (AAA [15]) = 300 + 4 (15 – 5) = 340
LOC (AAA [35]) = 300 + 4 (35 – 5) = 420
AAA [55] is not an element of AAA, since 55 exceeds UB = 50.
Que 1.21. Suppose multidimensional arrays P and Q are declared
as P(– 2: 2, 2: 22) and Q(1: 8, – 5: 5, – 10 : 5) stored in column major order
i. Find the length of each dimension of P and Q.
ii. The number of elements in P and Q.
iii. Assuming base address (Q) = 400, W = 4, find the effective indices
E1, E2, E3 and address of the element Q[3, 3, 3].
AKTU 2018-19, Marks 07
Answer
i. The length of a dimension is obtained by
Length = Upper Bound – Lower Bound + 1
Hence, the lengths of the dimension of P are,
L1 = 2 – (– 2) + 1 = 5; L2 = 22 – 2 + 1 = 21
The lengths of the dimension of Q are,
L1 = 8 – 1 + 1 = 8; L2 = 5 – (– 5) + 1 = 11; L3 = 5 – (– 10) + 1 = 16
ii. Number of elements in P = 21 × 5 = 105 elements
Number of elements in Q = 8 × 11 × 16 = 1408 elements
iii. The effective index Ei is obtained from Ei = ki – LB, where ki is the given
index and LB, is the Lower Bound. Hence,
E1 = 3 – 1 = 2; E2 = 3 – (– 5) = 8; E3 = 3 – (– 10) = 13
The address depends on whether the programming language stores Q
in row major order or column major order. Assuming Q is stored in
column major order.
E3L2 = 13 × 11 = 143
E3L2 + E2 = 143 + 8 = 151
(E3L2)L1 = 151 * 8 = 1208
(E2L2+E2)L1 + E1 = 1208 + 2 = 1210
Therefore, LOC(Q[3,3,3]) = 400 + 4(1210) = 400 + 4840 = 5240
1–18 A (CS/IT-Sem-3) Array and Linked List
Questions-Answers
Answer
1. Arrays are used to implement mathematical vectors and matrices, as
well as other kinds of rectangular tables. Many databases, small and
large, consist of one-dimensional arrays whose elements are records.
2. Arrays are used to implement other data structures, such as lists, heaps,
hash tables, queues and stacks.
3. Arrays are used to emulate in-program dynamic memory allocation,
particularly memory pool allocation.
4. Arrays can be used to determine partial or complete control flow in
programs, as a compact alternative to multiple “if” statements.
5. The array may contain subroutine pointers (or relative subroutine
numbers that can be acted upon by SWITCH statements) that direct the
path of the execution.
Answer
1. Sparse matrices are the matrices in which most of the elements of the
matrix have zero value.
2. Two general types of n-square sparse matrices, which occur in various
applications, as shown in Fig. 1.23.1.
3. It is sometimes customary to omit block of zeros in a matrix as in
Fig. 1.23.1. The first matrix, where all entries above the main diagonal
are zero or, equivalently, where non-zero entries can only occur on or
below the main diagonal, is called a lower triangular matrix.
4. The second matrix, where non-zero entries can only occur on the diagonal
or on elements immediately above or below the diagonal, is called
tridiagonal matrix.
Data Structure 1–19 A (CS/IT-Sem-3)
4 5 –3
3 –5 1 4 3
1 0 6 9 –3 6
–7 8 –1 3 2 4 –7
(a) Triangular matrix (b) Tridiagonal matrix
Fig. 1.23.1.
Answer
There are two ways of representing sparse matrices :
1. Array representation :
i. In the array representation of a sparse matrix, only the non-zero
elements are stored so that storage space can be reduced.
ii. Each non-zero element in the sparse matrix is represented as (row,
column, value).
iii. For this a two-dimensional array containing three columns can be
used. The first column is for storing the row numbers, the second
column is for storing the column numbers and the third column
represents the value corresponding to the non-zero element at
(row, column) in the first two columns.
iv. For example, consider the following sparse matrix :
2 0 0 0
0 1 0 0
0 4 3 0
The above matrix can be represented as :
Row Column Value
0 0 2
1 1 1
2 1 4
2 2 3
2. Linked representation :
i. In the linked list representation each node has four fields. These
four fields are defined as :
a. Row : Index of row, where non-zero element is located.
b. Column : Index of column, where non-zero element is located.
c. Value : Value of non-zero element located at index – (row,
column).
d. Next node : Address of next node.
Node structure : Row Column Value Address
1–20 A (CS/IT-Sem-3) Array and Linked List
0 0 3 0
Example : 0 0 5 7
0 2 0 0
Start
0 2 3 1 2 5 1 3 7 2 1 2 Null
Answer
1. The matrix, where all entries above the main diagonal are zero or
equivalently, where non-zero entries can only occur, on or below the
main diagonal, is called lower triangular matrix.
2. A matrix in which all the entries below the main diagonal are zero is
called upper triangular matrix.
Space efficient representation for sparse matrices : Refer Q. 1.24,
Page 1–19A, Unit-1.
Questions-Answers
Answer
i. Linked list :
1. A linked list, or one-way list, is a linear collection of data elements,
called nodes, where the linear order is given by means of pointers.
Data Structure 1–21 A (CS/IT-Sem-3)
Start
Information part of third node
Next pointer field of third node
×
Fig. 1.26.1.
2. Each node is divided into two parts: the first part contains the
information of the element, and the second part, called the link
field or next pointer field, contains the address of the next node in
the list.
Program :
#include<stdio.h>
#include<conio.h>
#include<alloc.h>
struct node {
int info;
struct node *link;
} ;
struct node *first;
void main( )
i. Insert at beginning :
void insert_beginning( ) {
struct node *ptr;
ptr = (struct node*)malloc(sizeof(struct node));
if (ptr == NULL) {
printf (“overflow\n” ) ;
return;
}
printf (“input new node information”);
scanf (“%d”, &ptr -> info) ;
ptr -> link = first;
first = ptr;
}
ii. Insert at end :
void insert_end( ) {
struct node *ptr; *cpt;
ptr = (struct node*)malloc(sizeof(struct node));
if (ptr == NULL) {
printf (“Link list is overflow\n”);
return;
}
printf (“input new node information”);
scanf (“%d”, &ptr -> info);
cpt = first;
while (cpt -> link != NULL)
cpt = cpt -> link;
1–22 A (CS/IT-Sem-3) Array and Linked List
Que 1.28. Implement linear linked list using pointer for following
functions :
i. Insert at beginning ii. Insert at end
iii. Insert after element iv. Delete at end
v. Delete at beginning vi. Delete after element
vii. Display in reverse order
Answer
#include<stdio.h>
#include<conio.h>
#include<process.h>
typedef struct simplelink {
int data;
struct simplelink *next;
1–26 A (CS/IT-Sem-3) Array and Linked List
} node;
i. Function to insert at beginning :
node *insert_begin(node *p)
{
node *temp;
temp = (node *)malloc(sizeof(node));
printf(“\nEnter the inserted data:”);
scanf(“%d”,&temp->data);
temp->next = p;
p = temp;
return(p);
}
ii. Function to insert at end :
node *insert_end(node *p){
node *temp, *q;
q = p;
temp=(node*)malloc(sizeof(node));
printf(“\nEnter the inserted data;”);
scanf(“%d”,&temp->data);
while(p->next != NULL)
{
p = p->next;
}
p->next = temp;
temp->next = (node *)NULL;
return(q);
}
iii. Function to insert after element:
node *insert_after(node *p) {
node temp, *q;
int x;
q = p;
printf(“\nEnter the data(after which you want to enter data):”);
scanf(“%d”,&x);
while(p->data != x) {
p = p->next;
}
temp = (node *)malloc(sizeof(node));
printf(“\nEnter the inserted data:”);
scanf(“%d”,&temp->data);
temp->next = p->next;
p->next = temp;
return (q);
}
iv. Function to delete last node :
node *del end(node *p) {
Data Structure 1–27 A (CS/IT-Sem-3)
node * q, *r;
r = p;
q = p;
if(p->next == NULL)
{
r = (node *)NULL;
}
else
{
while(p->next := NULL)
{
q = p;
p = p->next;
}
q->next = (node *)NULL;
}
free(p);
return(r);
}
v. Function to delete first node :
node *delete_begin(node *p) {
node *q;
q = p;
q = p->next;
free(q);
return(p);
}
vi. Function to delete node after element :
node “delete_after(node, *p)
{
node *temp, *q;
int x;
q = p;
printf(“\nEnter the data(after which you want to delete):”);
scanf(“%d” ,&x);
while(p->data != x) {
p = p->next;
}
temp = p->next;
p->next = temp->next;
free(temp);
return (q);
}
vii. Function to reverse the list :
node *reverse(node *p) {
node *q, *r;
1–28 A (CS/IT-Sem-3) Array and Linked List
q = (node *)NULL;
while(p != NULL) {
r = q;
q = p;
p = p->next;
p->next = r;
}
return(q);
}
Que 1.29. What are the advantages and disadvantages of single
linked list ?
Answer
Advantages :
1. Linked lists are dynamic data structures as it can grow or shrink during
the execution of a program.
2. The size is not fixed.
3. Data can store non-continuous memory blocks.
4. Insertion and deletion of nodes are easier and efficient. Unlike array a
linked list provides flexibility in inserting a node at any specified position
and a node can be deleted from any position in the linked list.
5. Many more complex applications can be easily carried out with linked
lists.
Disadvantages :
1. More memory : In the linked list, there is a special field called link field
which holds address of the next node, so linked list requires extra space.
2. Accessing to arbitrary data item is complicated and time consuming
task.
Answer
1. To reverse a linear linked list, three pointer fields are used.
2. These are PREV, PTR, REV which hold the address of previous node,
current node and will maintain the linked list.
Algorithm :
1. PTR = FIRST
2. TPT = NULL
3. Repeat step 4 while PTR != NULL
4. REV = PREV
Data Structure 1–29 A (CS/IT-Sem-3)
5. PREV = PTR
6. PTR = PTR LINK
7. PREV LINK = REV
[End of while loop]
8. START = PREV
9. Exit
Answer
Questions-Answers
Answer
1. The doubly or two-way linked list uses double set of pointers, one pointing
to the next node and the other pointing to the preceding node.
2. In doubly linked list, all nodes are linked together by multiple links
which help in accessing both the successor and predecessor node for
any arbitrary node within the list.
3. Every node in the doubly linked list has three fields :
Fig. 1.32.1.
4. LPT will point to the node in the left side (or previous node) i.e., LPT will
hold the address of the previous node, RPT will point to the node in the
right side (or next node) i.e., RPT will hold the address of the next node.
5. INFO field store the information of the node.
6. A doubly linked list can be shown as follows :
LPT RPT
Answer
Doubly linked list : Refer Q. 1.32, Page 1–30A, Unit-1.
Program :
# include<stdio.h>
Data Structure 1–31 A (CS/IT-Sem-3)
# include<conio.h>
# include<alloc.h>
struct node
{
int info ;
struct node *lpt ;
struct node *rpt ;
};
struct node *first ;
void main ( )
{
create ( ) ;
getch ( ) ;
}
void create ( )
{
struct node *ptr, *cpt ;
char ch ;
ptr = (struct node *) malloc (size of (struct node)) ;
printf (“Input first node information”) ;
scanf (“%d”, & ptr info) ;
ptr lpt = NULL ;
first = ptr ;
do
{
cpt = (struct node *) malloc (size of (struct node)) ;
printf (“Input next node information”);
scanf (“%d”, & cpt info) ;
ptr rpt = cpt ;
cpt lpt = ptr ;
ptr = cpt ;
printf (“Press <Y/N> for more node”) ;
ch = getch ( );
}
while (ch == ‘Y’) ;
ptr rpt = NULL ;
}
Que 1.34. Implement doubly linked list using pointer for following
functions :
i. Insert at beginning
ii. Insert at end
iii. Searching an element
iv. Delete at beginning
v. Delete at end
vi. Delete entire list
1–32 A (CS/IT-Sem-3) Array and Linked List
Answer
#include<stdio.h>
#include<conio.h>
typedef struct n{
int data;
struct n *prev;
struct n *next;
}node;
node *head = NULL, *tail = NULL;
i. Function to insert at beginning :
void insert beg(node*h, int d) {
node *temp;
temp = (node *)malloc(sizeof(node));
temp->data = d;
temp->prev = NULL;
if(head == NULL)
{
temp->next = NULL;
head = tail = temp;
return;
}
temp->next = h;
h->prev = temp;
h = h->prev;
head = h;
}
ii. Function to insert at end :
void insert_end(node *t, int d) {
node *temp;
temp = (node*)malloc(sizeof(node));
temp->data = d;
temp->next = NULL;
if(head == NULL) {
temp->prev = NULL;
head = tail = temp;
return;
}
temp->prev = t;
t->next = temp;
t = t->next;
tail = t;
}
iii. Function to search an element :
node *find(node *h, int aft) {
while(h->next != head && h->data != aft)
Data Structure 1–33 A (CS/IT-Sem-3)
h = h->next;
if(h->next == head && h->data != aft)
return (node*) NULL;
else
return h;
}
iv. Function to delete at beginning :
void delete_beg(node *h, node *t) {
if(head == (node*)NULL) {
printf(“\nList is empty.”);
getch( );
return;
}
if(head == tail) {
free(h);
head = tail = (node *)NULL;
return;
}
if(h->next == t) {
tail->prev = NULL;
head = tail;
}
else {
head = head->next;
head->prev = NULL;
}
free(h);
}
v. Function to delete at end :
void delete_end(node *h, node *t) {
if(head == (node *)NULL) {
printf(“\nList is empty.”);
getch( );
return;
}
if(head == tail) {
free(h);
head = tail = (node*)NULL;
return;
}
if(t->prev == h) {
head->next = NULL;
tail = head;
}
else {
tail = tail->prev;
tail->next = NULL;
1–34 A (CS/IT-Sem-3) Array and Linked List
}
free(t);
}
void display(node *h) {
while(h != NULL) {
printf(n“/%d”, h->data);
h = h->next;
}
}
vi. Function to delete entire list :
void free_list(node *list) {
node *t;
while(list != NULL) {
t = list;
list = list->next;
free(t);
}
}
Answer
i. Traversing of two-way linked list :
a. Forward Traversing :
1. PTR FIRST.
2. Repeat step 3 to 4 while PTR != NULL.
3. Process INFO (PTR).
4. PTR RPT (PTR).
5. STOP.
b. Backward Traversing :
1. PTR FIRST.
2. Repeat step (3) while RPT (PTR) != NULL.
3. PTR RPT (PTR)
4. Repeat step (5) to (6) while PTR != NULL.
5. Process INFO (PTR).
6. PTR LPT (PTR).
7. STOP.
Data Structure 1–35 A (CS/IT-Sem-3)
Answer
Program to delete a specific element from a single linked list :
#include <stdio.h>
1–36 A (CS/IT-Sem-3) Array and Linked List
#include <stdlib.h>
// A linked list node
struct Node
{
int data;
struct Node *next;
};
/* Given a reference (pointer to pointer) to the head of a list
and an int, inserts a new node on the front of the list. */
void push(struct Node** head_ref, int new_data)
{
struct Node* new_node = (struct Node*) malloc(sizeof(struct Node));
new_node->data = new_data;
new_node->next = (*head_ref);
(*head_ref) = new_node;
}
/* Given a reference (pointer to pointer) to the head of a list
and a position, deletes the node at the given position */
void deleteNode(struct Node **head_ref, int position)
{
// If linked list is empty
if (*head_ref == NULL)
return;
// Store head node
struct Node* temp = *head_ref;
// If head needs to be removed
if (position == 0)
{
*head_ref = temp->next; // Change head
free(temp); // free old head
return;
}
// Find previous node of the node to be deleted
for (int i = 0; temp != NULL && i < position – 1; i++)
temp = temp->next;
// If position is more than number of nodes
if (temp == NULL || temp->next == NULL)
return;
// Node temp->next is the node to be deleted
// Store pointer to the next of node to be deleted
struct Node *next = temp->next->next;
// Unlink the node from linked list
free(temp->next); // Free memory
temp->next = next; // Unlink the deleted node from list
}
// This function prints contents of linked list starting from
// the given node
Data Structure 1–37 A (CS/IT-Sem-3)
Questions-Answers
Answer
Circular linked list : A circular list is a linear linked list, except that the last
element points to the first element, Fig. 1.37.1 shows a circular linked list
with 4 nodes for non-empty circular linked list, there are no NULL pointers.
start
Fig. 1.37.1.
Functions :
a. To create a list : Refer Q. 1.33, Page 1–30A, Unit-1.
b. To insert after a specific node :
void insert_given_node ( )
{
struct node *ptr, *cpt, *tpt, *rpt, *lpt;
int m;
ptr = (struct node *) malloc (size of (struct node));
if (ptr == NULL)
{
printf (“OVERFLOW”);
return;
}
printf (“input new node information”);
scanf (“%d”, & ptr info);
printf (“input node information after which insertion”);
scanf (“%d”, & m);
cpt = first;
while (cpt info != m)
cpt = cpt rpt;
tpt = cpt rpt;
cpt rpt = ptr;
Data Structure 1–39 A (CS/IT-Sem-3)
Answer
#include<stdio.h>
#include<conio.h>
typedef struct n{
int data;
struct n *next;
}node;
node *head = NULL;
Data Structure 1–41 A (CS/IT-Sem-3)
while(h->next != head)
h = h->next;
h->next = temp;
head = temp;
}
else
loc->next = temp;
}
void display (node *h) {
while (h->next != head) {
printf(“%d”, h->data);
h = h->next;
}
printf(“%d”, h->data);
}
iii. Function to delete at the end :
void delete_cir_end(node *h) {
node *temp;
if(head == NULL) {
printf(“\nList is empty”);
getch( );
}
if(h->next == head) {
printf(“\nNode deleted. List is empty”);
getch( );
head = NULL;
free(h);
return;
}
while(h->next != head) {
temp = h;
h = h->next;
}
temp->next = h->next;
free(h);
}
iv. Function to delete entire list :
void free_list(node *list) {
node *t;
while(list != NULL) {
t = list;
list = list->next;
}
}
Data Structure 1–43 A (CS/IT-Sem-3)
Answer
1. If PTR = NULL
2. Write OVERFLOW
3. Go to Step 1
[END OF IF]
4. SET NEW_NODE = PTR
5. SET PTR = PTR -> NEXT
6. SET NEW_NODE -> DATA = VAL
7. SET NEW_NODE -> NEXT = HEAD
8. SET TEMP = HEAD
9. Repeat Step 10 while TEMP -> NEXT != HEAD
10. SET TEMP = TEMP -> NEXT
[END OF LOOP]
11. SET TEMP -> NEXT = NEW_NODE
12. EXIT
Questions-Answers
Answer
Refer Q. 1.27, Page 1–23A, Unit-1.
Answer
Refer Q. 1.34, Page 1–31A, Unit-1.
1–44 A (CS/IT-Sem-3) Array and Linked List
Answer
Function for forward traversing :
void ftraverse ( )
{
struct node *ptr;
printf (“forward traversing :/n”);
ptr = first ;
while (ptr != NULL)
{
printf (“%d \n”, ptr -” info) ;
ptr = ptr -> rpt;
}
}
Function for backward traversing :
void btraverse ( )
{
struct node * ptr ;
printf (“Backward traversing :\n”)
ptr = first ;
while (ptr rpt != NULL)
ptr = ptr rpt ;
while (ptr != NULL)
{
printf (“%d \n”, ptr -> info) ;
ptr = ptr -> lpt;
}
}
Answer
#include<stdio.h>
#include<conio.h>
#include<alloc.h>
struct node
{
int info;
struct node *link;
} ;
struct node *first;
void main( )
Data Structure 1–45 A (CS/IT-Sem-3)
{
void create( ), traverse( ), insert_beg( ), insert_end( ),
delete_beg( ), delete_end( );
clrscr( ) :
create( ) ;
traverse( ) ;
insert_beg( ) ;
traverse( ) ;
insert_end( ) ;
traverse( ) ;
delete_beg( ) ;
traverse( ) ;
getch( ) ;
}
void create( )
{
struct node *ptr, *cpt ;
char ch ;
ptr = (struct node *) malloc (size of (struct node)) ;
printf(“input first node”) ;
scanf(“%d” & ptr -> info) ;
first = ptr ;
do {
cpt = (struct node *) malloc (size of (struct node)) ;
printf (“Input next node”) ;
scanf (“%d” & cpt -> info) ;
ptr -> link = cpt ;
ptr = cpt ;
print f (“Press <Y/N> for more node”) ;
ch = getch ( ) ;
}
while (ch == “Y”);
ptr -> link = first ;
}
void traverse ( )
{
struct node *ptr ;
printf (“Traversing of link list ; \n”) ;
ptr = first ;
while = (ptr != first)
{
printf (“%d\n”, ptr -> info) :
ptr = ptr -> link ;
}
}
void insert_beg ( )
{
1–46 A (CS/IT-Sem-3) Array and Linked List
free (ptr) ;
}
void delete_end( )
{
struct node *ptr, *cpt;
if (first == NULL)
{
printf (“underflow\n”);
return;
}
cpt = first;
while (cpt -> link != first)
{
ptr = cpt;
cpt = cpt -> link;
}
ptr -> link = first;
free (cpt);
}
Que 1.44. Explain the method to represent the polynomial
equation using linked list.
Answer
1. In the linked representation of polynomials, each node should consist of
three elements, namely coefficient, exponent and a link to the next
term.
2. The coefficient field holds the value of the coefficient of a term, the
exponent field contains the exponent value of that term and the link
field contains the address of the next term in the polynomial.
Fig. 1.44.1.
For example : Let us consider the polynomial of degree 4 i.e., 3x4 + 8x2
+ 6x + 8 can be written as 3 * power (x, 4) + 8 * power (x, 2) + 6 * power
(x, 1) + 8 * power (x, 0)
It can be represented as linked list as
3 4 8 2 6 1 8 0 NULL
Fig. 1.44.2.
3. The link coming out of the last node is NULL pointer.
In case of polynomial of 3 variables i.e., x, y, z can also be represented as
linked list as shown in Fig. 1.44.3.
1–48 A (CS/IT-Sem-3) Array and Linked List
Fig. 1.44.3.
For example : Let us consider the following polynomial of 3 variable
3x2 + 2xy2 + 5y3 + 7yz.
We can replace each term of the polynomial with node of the linked list
as
2 0 0 3 1 2 0 2 0 3 0 5 0 1 1 7 NULL
Fig. 1.44.4.
Answer
Representation of polynomial : Refer Q. 1.44, Page 1–47A, Unit-1.
Addition of two polynomials using linked lists :
Let p and q be the two polynomials represented by the linked list.
1. While p and q are not null, repeat step 2.
2. If powers of the two terms are equal then,
if the terms do not cancel then insert the sum of the terms into the sum
(resultant)
Polynomial
Update p
Update q
Else if the (power of the first polynomial) > (power of second polynomial)
Then insert the term from first polynomial into sum polynomial
Update p
Else insert the term from second polynomial into sum polynomial
Update q
3. Copy the remaining terms from the non-empty polynomial into the sum
polynomial.
Example : Let us consider the addition of two polynomials of single variable
5x4 + 6x3 + 2x2 + 10x + 4 and 7x3 + 3x2 + x + 7. We can visualize this as follows :
5 x4 6 x3 2 x 2 10 x 4
7 x 3 3 x2 x 7
5 x 4 13 x3 5 x 2 11 x 11
i.e., to add two polynomials, compare their corresponding terms starting
from the first node and move towards the end node.
Data Structure 1–49 A (CS/IT-Sem-3)
Answer
1. The multiplication of polynomials is performed by multiplying coefficient
and adding the respective power.
2. To produce the multiplication of two polynomials following steps are
performed :
a. Check whether two given polynomials are non-empty. If anyone
polynomial is empty then polynomial multiplication is not possible.
So exit.
b. Second polynomial is scanned from left to right.
c. For each term of the second polynomial, the first polynomial is
scanned from left to right and its each term is multiplied by the
term of the second polynomial, i.e., find the coefficient by multiplying
the coefficients and find the exponent by adding the exponents.
d. If the product term already exists in the resulting polynomial then
its coefficients are added, otherwise a new node is inserted to
represent this product term.
For example : Let us consider two polynomial 8x4 + 6x2 + 5x + 2 and
3x2 + x + 2 and perform multiplication as
4 2
8x + 6 x + 5 x + 2
2
× 3x + x + 2
6 4 3 2
24x + 18x + 15 x + 6x
5 3 2
+ 8x + 6x + 5 x + 2x
4 2
+16x + 12x + 10x + 4
6 5 4 3 2
24x + 8x + 34x + 21 x + 23x + 12x + 4
Data Structure 2–1 A (CS/IT-Sem-3)
CONTENTS
Part-1 : Stacks : Abstract Data Type ..................... 2–2A to 2–3A
Primitive Stack Operations :
Push and Pop
Questions-Answers
Que 2.1. What do you mean by stack ? Explain all its operation
with suitable example.
Answer
1. A stack is one of the most commonly used data structure.
2. A stack, also called Last In First Out (LIFO) system, is a linear list in
which insertion and deletion can take place only at one end, called top.
3. This structure operates in much the same way as stack of trays.
4. If we want to remove a tray from stack of trays it can only be removed
from the top only.
5. The insertion and deletion operation in stack terminology are known
as PUSH and POP operations.
top 4 6
3 –5
2 12
1 10
0 8
Stack of trays
(a) Stack after pushing 8, 10, 12, – 5, 6
top 5 9
4 11
3 7
top 2 12 2 12
1 10 1 10
0 8 0 8
(b) Stack after poping (c) Stack after pushing
elements 6, – 5 elements 7, 11, 9
Fig. 2.1.1.
Data Structure 2–3 A (CS/IT-Sem-3)
Answer
Refer Q. 1.13, Page 1–12A, Unit-1.
Que 2.3. Discuss PUSH and POP operation in stack and write
down their algorithm.
Answer
PUSH operation : In push operation, we insert an element onto stack.
Before inserting, first we increase the top pointer and then insert the element.
Algorithm :
PUSH (STACK, TOP, MAX, DATA)
1. If TOP = MAX – 1 then write “STACK OVERFLOW and STOP”
2. READ DATA
3. TOP TOP + 1
4. STACK [TOP] DATA
5. STOP
POP operation : In pop operation, we remove an element from stack. After
every pop operation top of stack is decremented by 1.
Algorithm :
POP (STACK, TOP, ITEM)
1. If TOP < 0 then write “STACK UNDERFLOW and STOP”
2. STACK [TOP] NULL
3. TOP TOP – 1
4. STOP
Questions-Answers
Answer
#include<stdio.h>
#include<conio.h>
#define MAX 50
int stack [MAX + 1], top = 0 ;
void main( )
{
clrscr( );
void create( ), traverse( ), push( ), pop( );
create( );
printf(“\n stack is:\n”);
traverse( );
push( );
printf(“After Push the element in the stack is :\n”);
traverse( );
pop( );
printf(“After Pop the element in the stack is :\n”);
traverse( );
getch( );
}
void create( )
{
char ch;
do
{
top ++;
printf(“Input Element”);
scanf (“%d”, stack[top]);
printf(“Press<Y>for more element\n”);
ch = getch( );
}
while (ch == ‘Y’ )
}
void traverse( )
{
Data Structure 2–5 A (CS/IT-Sem-3)
int i ;
for(i = top; i > 0; – –i)
printf(“%d\n”, stack[i]);
}
void push( )
{
int m;
if(top == MAX)
{
printf(“Stack is overflow”);
return;
}
printf(“Input new element to insert”);
scanf(“%d”, &m) ;
top++;
stack[top] = m;
}
void pop( )
{
if(top == 0)
{
printf(“Stack is underflow\n”);
return;
}
stack[top] = ‘\0’ ;
top – – ;
}
Answer
#include<stdio.h>
#include<conio.h>
#include<alloc.h>
struct node
{
int info;
struct node *link;
};
struct node *top;
void main()
{
void create(), traverse(), push(), pop();
create();
2–6 A (CS/IT-Sem-3) Stacks and Queues
{
printf(“Overflow\n”);
return;
}
printf(“Input New node information”);
scanf(“%d”, &ptr -> info);
ptr ->link = top;
top = ptr;
}
void pop()
{
struct node *ptr;
if(top == NULL)
{
printf (“Underflow \n”);
return;
}
ptr = top;
top = ptr ->link;
free (ptr);
}
Que 2.6. What is stack ? Implement stack with singly linked list.
Answer
Stack : Refer Q. 2.1, Page, 2–2A Unit-2.
Implementation using singly linked list :
typedef struct stack
{
int *data;
struct stack *next;
}stack;
void push(stack **top, int *data)
{
stack *newn;
newn = (stack *)malloc(sizeof(stack));
newn->data = data;
newn->next = (stack *)NULL;
if(*top == NULL)
{
*top = newn;
return;
}
newn->next = (*top);
*top = newn;
2–8 A (CS/IT-Sem-3) Stacks and Queues
}
int *pop(stack **top)
{
int *rval = (int *)NULL;
stack *tmp;
if(*top != NULL)
{
tmp = *top;
*top = (*top)->next;
rval = tmp->data;
free(tmp);
}
return(rval);
}
Answer
Stack : Refer Q. 2.1, Page 2–2A, Unit-2.
#include<stdio.h>
#include<conio.h>
#include<string.h>
#define MAX 20
int top = – 1;
char stack [MAX];
char pop();
push(char);
main()
{
clrscr();
char str [20];
int i;
printf(“Enter the string : ”);
gets(str);
for(i = 0; i < strlen(str); i++)
push (str [i]);
for(i = 0; i < strlen(str); i++)
str[i] = pop();
printf(“Reversed string is :”);
Data Structure 2–9 A (CS/IT-Sem-3)
puts (str);
getch();
}
push (char item)
{
if(top == MAX – 1)
printf(“Stack overflow\n”);
else
stack[++top] = item;
}
char pop()
{
if(top == – 1)
printf(“Stack underflow \n”);
else
return stack [top – –];
}
Questions-Answers
Answer
Applications of stack are as follows :
1. Expression evaluation : Stack is used to evaluate prefix, postfix and
infix expressions.
2. Expression conversion : An expression can be represented in prefix,
postfix or infix notation. Stack can be used to convert one form of
expression to another.
3. Syntax parsing : Many compilers use a stack for parsing the syntax of
expressions, program blocks etc. before translating into low level code.
4. Parenthesis checking : Stack is used to check the proper opening and
closing of parenthesis.
2–10 A (CS/IT-Sem-3) Stacks and Queues
Que 2.9. Write down the algorithm to convert infix notation into
postfix.
OR
Write down algorithm to evaluate the infix expression.
Answer
Polish (Q, P)
Let Q is an arithmetic expression written in infix notation. This algorithm
finds the equivalent postfix expression P.
1. Push “(”onto STACK, and add “)” to end of Q.
2. Scan Q from left to right and repeat steps 3 to 6 for each element of Q
until the STACK is empty.
3. If an operand is encountered, add it to P.
4. If a left parenthesis is encountered push it onto STACK.
5. If an operator is encountered, then :
a. Repeatedly pop from STACK and add to P each operator (on the top
of STACK) which has the same precedence as or higher precedence
than .
b. Add to STACK.
[End if]
6. If a right parenthesis is encountered, then :
a. Repeatedly pop from STACK and add to P each operator (on the top
of STACK) until a left parenthesis is encountered.
b. Remove the left parenthesis [Do not add it to P]
[End if]
[End of step 2]
7. End.
Answer
(A + (B *C + D)/E)
Character Stack Postfix
( (
A ( A
+ (+ A
( (+( A
B (+( AB
* (+(* AB
C (+(* ABC
+ (+(+ ABC*
D (+(+ ABC*D
) (+ ABC*D+
/ (+/ ABC*D+
E (+/ ABC*D+E
) ( ABC*D+E/+
Resultant postfix expression : ABC * D + E/+
Que 2.11. Consider the following infix expression and convert
into reverse polish notation using stack. A + (B * C – (D/E ^ F) * H)
AKTU 2018-19, Marks 07
Answer
A + (B*C – (D/E ^ F)*H)
Character Stack Postfix
A ( A
+ (+ A
( (+( A
B (+( AB
* ( + (* AB
C ( + (* ABC
– ( + (– ( ABC*
( (+(–( ABC*
D ( + (– ( ABC*D
/ ( + (– ( / ABC*D
E ( + (– (/ ABC*DE
^ ( + (– (/^ ABC*DE
F ( + (– (/^ ABC*DEF
) ( + (– (/^ ABC*DEF
* ( + (– * ABC*DEF ^/
H ( + (– * ABC*DEF ^/ H
Resultant reverse polish expression : ABC * DEF ^ / H
2–12 A (CS/IT-Sem-3) Stacks and Queues
Answer
This algorithm finds the value of an arithmetic expression P written in postfix
notation.
1. Add a right parenthesis “)” to P.
[This acts as a sentinel]
2. Scan P from left to right and repeat step 3 and 4 for each element of
P until the sentinel “)” is encountered.
3. If an operand is encountered, put it on STACK.
4. If an operator is encountered then :
a. Remove the top two elements of STACK, where A is the top element
and B is the next-to-top element.
b. Evaluate B A.
c. Place the result of (b) back on STACK.
[End of if structure]
[End of step 2 loop]
5. Set value equal to top element on STACK.
6. End.
Answer
a. E = (A + B) * C + D / (B + A * C) + D
Postfix : E = (A + B) * C + D / (B + T1) + D T1 = AC *
= (A + B) * C + D / T2 + D T2 = BT1 +
= T3 * C + D / T2 + D T3 = AB +
= T3 * C + T4 + D T4 = DT2/
= T5 + T4 + D T5 = T3 C *
= T6 + D T6 = T5T4 +
= T7 T7 = T6D +
On putting the values of T’s
= T6D +
= T5T4 + D +
= T3 C * DT2 / + D +
= AB + C * DBT1 + / + D +
= AB + C * DBAC * + / + D +
Data Structure 2–13 A (CS/IT-Sem-3)
Prefix : E = (A + B) * C + D / (B + A * C) + D
= (A + B) * C + D / (B + T1) + D T1 = * AC
= (A + B) * C + D / T2 + D T2 = + BT1
= T3 * C + D / T2 + D T3 = + AB
= T3 * C + T4 + D T4 = / DT2
= T5 + T4 + D T5 = * T3C
= T6 + D T6 = + T5T4
= T7 T7 = + T6D
On putting the values of T’s
E = + T6D
= + + T5 T4D
= + + * T3C / DT2D
= + + * + ABC / D + B T1D
= + + * + ABC / D + B * ACD
b. E = A /B C + D * E – A * C
Postfix : E = A / T1 + D * E – A * C T1 = BC ^
= T2 + D * E – A * C T2 = AT1/
= T2 + T3 – A * C T3 = DE *
= T2 + T3 – T4 T4 = AC *
= T5 – T4 T5 = T2T3 +
= T6 T6 = T5 T4 –
On putting the values of T’s
= T5 T4 –
= T2 T3 + AC *
= AT1/DE * + AC *
= ABC /DE * + AC *
Prefix : E = A /B C + D * E – A * C
= A / T1 + D * E – A * C T1 = BC
= T2 + D * E – A * C T2 = /AT1
= T2 + T3 – A * C T3 = * DE
= T2 + T3 – T4 T4 = * AC
= T5 – T4 T5 = + T2T3
= T6 T6 = – T5 T4
On putting the values of T’s
= – T5T4
= – + T2T3 * AC
2–14 A (CS/IT-Sem-3) Stacks and Queues
= – + / AT1 * DE * AC
= – + / A ^BC * DE * AC
Que 2.14. Solve the following :
a. ((A – (B + C) * D) / (E + F)) [Infix to postfix]
b. (A + B) + *C – (D – E) F [Infix to prefix]
c. 7 5 2 + * 4 1 5 – / – [Evaluate the given postfix expression]
AKTU 2016-17, Marks 10
Answer
a. ((A – (B + C)*D)/(E + F))
((A – (B + C)*D)/ (EF + ))
X
((A – (B + C)*D)/X)
((A – (BC +) * D) / X)
Y
((A – (Y * D)) / X
((A – (YD *)) / X)
Z
((A – Z)) / X)
((AZ –) / X)
T
(T / X)
TX/
Now put the values,
AZ – EF + /
AYD * – EF + /
ABC + D * – EF + /
This is the required postfix form.
b. (A + B) + *C – (D – E) F
(+ AB) + * C – (D – E) F
X
X + * C – (D – E) F
X + * C – (– DE) F
Y
X + * C – (Y F)
X + * C – (Y F)
Z
X + *(C – Z)
Data Structure 2–15 A (CS/IT-Sem-3)
X + * (– CZ)
T
X+*T
* + XT
Now put the values,
* + + AB – CZ
* + + AB – C YF
* + + AB – C – DEF
This is the required prefix form.
c. 752 + * 415 – / – :
i. First this expression is converted into infix expression as :
Symbol scanned Stack
7 7
5 7, 5
2 7, 5, 2
+ 7, 5 + 2
* 7*(5 + 2)
4 7*(5 + 2), 4
1 7*(5 + 2), 4, 1
5 7*(5 + 2), 4, 1, 5
– 7*(5 + 2), 4, 1 – 5
/ 7*(5 + 2), 4/(1 – 5)
– (7*(5 + 2)) – (4/(1 – 5))
2
527
5
7 7 * 7 49
7
5
1 1 15 4
4 4 4 4 4/ 4 1
49 49 49 49 49
49 ( 1) 50
– occurred
Hence, the value is 50
2–16 A (CS/IT-Sem-3) Stacks and Queues
Questions-Answers
Answer
1. Iteration is the repetition of a process in order to generate a (possibly
unbounded) sequence of outcomes.
2. The sequence will approach some end point or end value.
3. Each repetition of the process is a single iteration, and the result of each
iteration is then the starting point of the next iteration.
4. Iteration allows us to simplify our algorithm by stating that we will
repeat certain steps until told.
5. This makes designing algorithms quicker and simpler because they do
not have to include lots of unnecessary steps.
6. Iteration is used in computer programs to repeat a set of instructions.
7. Count controlled iteration will repeat a set of instructions upto a specific
number of times, while condition controlled iteration will repeat the
instructions until a specific condition is met.
Answer
1. Recursion is a process of expressing a function that calls itself to perform
specific operation.
2. Indirect recursion occurs when one function calls another function that
then calls the first function.
3. Suppose P is a procedure containing either a call statement to itself or
a call statement to a second procedure that may eventually result in a
call statement back to the original procedure P.
4. Then P is called recursive procedure. So the program will not continue
to run indefinitely.
Data Structure 2–17 A (CS/IT-Sem-3)
Answer
Recursion : Refer Q. 2.16, Page 2–16A, Unit-2.
Program :
#include<stdio.h>
#include<conio.h>
int sum(int n)
{
if(n < 10)
return(n);
else
return(n % 10 + sum (n / 10));
}
main()
{
int s,n;
printf(“\nEnter any number:”);
scanf(“%d”,&n);
s = sum(n);
printf(“\nSum of digits = %d”, s);
getch();
return 0;
}
2–18 A (CS/IT-Sem-3) Stacks and Queues
Time complexity :
i. Assume that n is a 10 digit number. The function is called 10 times as the
problem is reduced by a factor of 10 each time the program recurse.
ii. So, we can conclude that time taken by program is linear in terms of the
length of the digit of the input number n.
iii. So, time complexity is,
T(n) = O(length of digit of (n)) where n is the number whose sum of
individual digit is to be found.
Answer
Types of recursion :
a. Direct recursion : A function is directly recursive if it contains an
explicit call to itself.
For example :
int foo (int x)
{ if (x <= 0)
return x;
return foo (x – 1);
}
b. Indirect recursion: A function is indirectly recursive if it contains a
call to another function.
For example :
int foo (int x)
{ if (x <= 0)
return x;
return bar (x) ;
}
int bar (int y)
{ return foo (y – 1) ;
}
c. Tail recursion :
1. Tail recursion (or tail-end recursion) is a special case of recursion in
which the last operation of the function, the tail call is a recursive
call. Such recursions can be easily transformed to iterations.
2. Replacing recursion with iteration, manually or automatically, can
drastically decrease the amount of stack space used and improve
efficiency.
3. Converting a call to a branch or jump in such a case is called a tail
call optimization.
For example :
Consider this recursive definition of the factorial function in C :
factorial (n)
Data Structure 2–19 A (CS/IT-Sem-3)
{
if( n == 0)
return 1;
return n * factorial (n – 1);
}
4. This definition is tail recursive since the recursive call to factorial is
not the last thing in the function (its result has to be multiplied by
n).
factorial (n, accumulator)
{
if(n == 0)
return accumulator;
return factorial (n – 1, n * accumulator);
}
factorial (n)
{
return factorial (n – 1) ;
}
d. Linear and tree recursive :
1. A recursive function is said to be linearly recursive when no pending
operation involves another recursive call to the function.
2. A recursive function is said to be tree recursive (or non-linearly
recursive) when the pending operation does involve another
recursive call to the function.
3. The Fibonacci function fib provides a classic example of tree
recursion. The Fibonacci numbers can be defined by the rule :
int fib (int n)
{ /* n >= 0 */
if (n == 0)
return 0;
if (n == 1)
return 1;
return fib (n – 1) + fib (n – 2) ;
}
The pending operation for the recursive call is another call to fib. Therefore,
fib is tree recursive.
Answer
1. Suppose three pegs, labelled A, B and C is given, and suppose on peg A,
there are finite number of n disks with decreasing size.
2. The object of the game is to move the disks from peg A to peg C using
peg B as an auxiliary.
2–20 A (CS/IT-Sem-3) Stacks and Queues
A B C
Fig. 2.19.1.
A B C A B C A B C
(6) B C (7) A C
Fig. 2.19.2.
Answer
Tower of Hanoi problem : Refer Q. 2.19, Page 2–19A, Unit-2.
Recursive code for Tower of Hanoi :
#include<stdio.h>
#include<conio.h>
void main()
Data Structure 2–21 A (CS/IT-Sem-3)
{
clrscr( );
int n;
char A = ‘A’, B = ‘B’, C = ‘C’;
void hanoi (int, char, char, char);
printf(“Enter number of disks :”);
scanf(“%d”, &n);
printf(“\n\n Tower of Hanoi problem with %d disks\n”, n);
printf(“Sequence is : \n”);
hanoi (n, A, B, C);
printf(“\n”);
getch();
}
void hanoi (int n, char A, char B, char C)
{
If(n ! = 0)
{
hanoi (n – 1, A, C, B);
printf(“Move disk %d from %c to %c\n , n, A, C,”);
hanoi (n – 1, B, A, C);
}
}
Answer
Tower of Hanoi problem : Refer Q. 2.19, Page 2–19A, Unit-2.
Algorithm :
TOWER (N, BEG, AUX, END)
2–22 A (CS/IT-Sem-3) Stacks and Queues
This procedure gives a recursive solution to the Tower of Hanoi problem for
N disks.
1. If N = 1, then :
a. Write: BEG END
b. Return
[End of If structure]
2. [Move N – 1 disk from peg BEG to peg AUX]
Call TOWER (N – 1, BEG, END, AUX)
3. Write: BEG END
4. [Move N – 1 disk from peg AUX to peg END]
Call TOWER (N – 1, AUX, BEG, END)
5. Return
Time complexity :
Let the time required for n disks is T(n).
There are 2 recursive calls for n – 1 disks and one constant time operation
to move a disk from ‘from’ peg to ‘to’ peg. Let it be kl.
Therefore,
T(n) = 2 T(n – 1) + k1
T(0) = k2 , a constant.
T(1) = 2k2 + k1
T(2) = 4k2 + 2k1+ k1
T(2) = 8k2 + 4k1+ 2k1 + k1
Coefficient of k1 = 2n
Coefficient of k2 = 2n – 1
Time complexity is O(2n) or O(an) where a is a constant greater than 1.
So, it has exponential time complexity.
Space complexity :
Space for parameter for each call is independent of n i.e., constant. Let it be
k.
When we do the 2nd recursive call 1st recursive call is over. So, we can reuse
the space of 1st call for 2nd call. Hence,
T(n) = T(n – 1) + k
T(0) = k
T(1) = 2k
T(2) = 3k
T(3) = 4k
So, the space complexity is O(n).
Data Structure 2–23 A (CS/IT-Sem-3)
Answer
1. Recursion is implemented through the use of function.
2. A function that contains a function call to itself or a function call to a
second function which eventually calls the first function, is known as a
recursive function.
3. Two important conditions must be satisfied by any recursive function :
a. Each time a function calls itself it must be closer, in some sense to
a solution.
b. There must be a discussion criterion for stopping the process or
computation.
2–24 A (CS/IT-Sem-3) Stacks and Queues
Answer
There are two ways to remove recursion :
1. By iteration : All tail recursion function can be removed by iterative
method.
2. By using stack : All non-tail recursion method can be removed by
using stack.
Que 2.24. Define the recurs ion. Write a recurs ive and
non-recursive program to calculate the factorial of the given
number. AKTU 2017-18, Marks 07
Answer
Recursion : Refer Q. 2.16, Page 2–16A, Unit-2.
Program :
#include <stdio.h>
#include <conio.h>
void main()
{
int n, a, b;
clrscr();
printf(“Enter any number\n”);
scanf(“%d”, &n);
a = recfactorial(n);
printf(“The factorial of a given number using recursion is %d
\n”, a);
b = nonrecfactorial(n);
printf(“The factorial of a given number using nonrecursion is
%d ”, b);
getch();
}
int recfactorial(int x)
{
int f;
if(x == 0)
{
return(1);
}
else
{
f = x * recfactorial(x – 1);
Data Structure 2–25 A (CS/IT-Sem-3)
return(f);
}
}
int nonrecfactorial(int x)
{
int i, f = 1;
for(i = 1; i <= x; i++)
{
f = f * i;
}
return(f);
}
Questions-Answers
Answer
1. Queue is a linear list which has two ends, one for insertion of elements
and other for deletion of elements.
2. The first end is called ‘Rear’ and the later is called ‘Front’.
3. Elements are inserted from Rear end and deleted from Front end.
4. Queues are called First In First Out (FIFO) list, since the first element in
a queue will be the first element out of the queue.
5. The two basic operations that are possible in a queue are :
a. Insert (or add) an element to the queue (push) or Enqueue.
b. Delete (or remove) an element from a queue (pop) or Dequeue.
Example :
Suppose we have an empty queue, with 5 memory cells such as :
0 1 2 3 4
Front = – 1
Rear = – 1 i.e., Empty queue.
2–26 A (CS/IT-Sem-3) Stacks and Queues
Answer
1. Insertion :
Insert in Q (Queue, Max, Front, Rear, Element)
Let Queue is an array, Max is the maximum index of array, Front and
Rear to hold the index of first and last element of Queue respectively
and Element is value to be inserted.
Step 1 : If Front = 1 and Rear = Max or if Front = Rear + 1
Display “Overflow” and Return
Step 2 : If Front = NULL [Queue is empty]
Set Front = 1 and Rear = 1
else if Rear = N, then
Set Rear = 1
else
Set Rear = Rear + 1
[End of if Structure]
Step 3 : Set Queue [Rear] = Element [This is new element]
Step 4 : End
2. Deletion :
Delete from Q (Queue, Max, Front, Rear, Item)
Step 1 : If Front = NULL [Queue is empty]
display “Underflow” and Return
Step 2 : Set Item = Queue [Front]
Step 3 : If Front = Rear [Only one element]
Set Front = Rear and Rear = NULL
Else if
Front = N, then
Set Front = 1
Else
Set Front = Front + 1
[End if structure]
Step 4 : End
3. Traversal of a queue : Here queue has Front End FE and Rear End
RE. This algorithm traverse queue applying an operation PROCESS to
each element of queue :
Step 1 : [Initialize counter] Set K = FE
Step 2 : Repeat step 3 and 4 while K RE
Step 3 : [Visit element] Apply PROCESS to queue [K]
Step 4 : [Increase counter] Set K = K + 1
[End of step 2 loop]
Step 5 : Exit
Data Structure 2–27 A (CS/IT-Sem-3)
Questions-Answers
Answer
1. A circular queue is one in which the insertion of a new element is done
at the very first location of the queue if the last location at the queue is
full.
2. In circular queue, the elements Q[0], Q[1], Q[2] ... Q[n – 1] is represented
in a circular fashion.
For example : Suppose Q is a queue array of six elements.
3. PUSH and POP operation can be performed on circular queue.
Fig. 2.27.1 will illustrate the same.
Q[5] Q[0] Q[5] Q[0]
Front
18
Q[4] Q[4]
7 Q[1] Q[1]
67 42 67 42
Q[3] Q[3] Q[2]
Q[2]
Rear Rear Front
(a) A circular queue after (b) A circular queue after
inserting 18, 7 , 42, 67. popping 18, 7.
Fig. 2.27.1.
C code to insert an element in circular queue :
void insert ()
{
int item;
if((front == 0 && rear == Max – 1)||((front == rear + 1))
{
printf(“Queue is overflow\n”);
return;
2–28 A (CS/IT-Sem-3) Stacks and Queues
}
if(front == –1) / *If queue is empty*/
{
front = 0;
rear = 0;
}
else
if(rear == Max – 1) /*rear is at last position of queue*/
rear = 0;
else
rear = rear + 1;
printf(“Input the element for insertion :”);
scanf(“%d”, &item);
cqueue [rear] = item;
}
Conditions for overflow : There are two conditions :
1. (front = 0) and (rear = Max – 1)
2. front = rear + 1
If any of these two conditions is satisfied, it means that overflow occurs.
Que 2.28. Write an algorithm to insert and delete an item from the
circular linked list.
Answer
Insertion in circular linked list :
i. At the beginning :
1. If AVAIL = NULL then linked list is OVERFLOW and STOP
2. PTR AVAIL
AVAIL LINK (AVAIL)
Read INFO (PTR)
3. CPT FIRST
4. Repeat step 5 while LINK (CPT) != FIRST
5. CPT LINK (CPT)
6. LINK (PTR) FIRST
FIRST PTR
LINK (CPT) FIRST
7. STOP
ii. At the end
1. If AVAIL = NULL then linked list is OVERFLOW and STOP
2. PTR AVAIL
AVAIL LINK (AVAIL)
Read INFO (PTR)
3. CPT FIRST
4. Repeat step 5 while LINK (CPT) != FIRST
5. CPT LINK (CPT)
6. LINK (CPT) PTR
Data Structure 2–29 A (CS/IT-Sem-3)
Answer
#include<stdio.h>
#include<conio.h>
#include<process.h>
#define MAX 10
typedef struct {
int front, rear ;
int elements [MAX];
} queue;
void createqueue (queue *aq) {
aq -> front = aq -> rear = – 1
}
int isempty (queue *aq)
{
if(aq -> front = = – 1)
return 1;
else
return 0;
2–30 A (CS/IT-Sem-3) Stacks and Queues
}
int isfull (queue *aq) {
if(((aq -> front = = 0) && (aq -> rear = = MAX – 1))
||(aq - > front == aq - > rear + 1))
return 1;
else
return 0;
}
void insert (queue *aq, int value) {
if(aq -> front = = – 1)
aq -> front = aq -> rear = 0;
else
aq -> rear = (aq -> rear + 1) % MAX;
aq -> element [aq -> rear] = value;
}
int delete (queue *aq) {
int temp;
temp = aq -> element [aq -> front];
if(aq -> front = = aq ->rear)
aq -> front = aq -> rear = – 1;
else
aq -> front = (aq -> front + 1) % MAX ;
return temp;
}
void main( )
{
int ch, elmt;
queue q;
create queue (&q);
while (1) {
printf(“1. Insertion \n”);
printf(“2. Deletion \n”);
printf(“3. Exit \n”);
printf(“Enter your choice”);
scanf(“%d”,&ch) ; .
switch (ch)
{
case 1:
if(isfull (&q))
{
printf (“queue is full”);
getch();
}
else
{
printf(“Enter value”);
Data Structure 2–31 A (CS/IT-Sem-3)
scanf(“%d”, &elmt) ;
insert (&q, elmt) ;
}
break;
case 2: if (isempty (&q))
{
printf(“queue empty”);
getch();
}
else
{
printf(“Value deleted is % d”, delete (&q));
getch( );
}
break;
case 3:
exit(1);
}
} }
Que 2.30. Write a C program to implement queue using linked list.
Answer
#include<stdio.h>
#include<conio.h>
#include<alloc.h>
#include<stdlib.h>
struct node
{
int info;
struct node *link;
};
struct node *front, *rear;
void main( )
{
clrscr( );
void insert( ), delete( ), display( );
int ch;
while (1)
{
printf(“1. Insert\n”);
printf(“2. Delete\n”);
printf(“3.Display\n”);
printf(“4. Exit\n”);
printf(“Enter your choice :”);
scanf(“%d”, &ch);
2–32 A (CS/IT-Sem-3) Stacks and Queues
switch(ch)
{
case 1 :
insert( );
break;
case 2 :
delete( );
break;
case 3 :
display( );
break;
case 4 :
exit(0);
default;
printf(“Please enter correct choice \n”);
}
}
getch( );
}
void insert( )
{
struct node *ptr;
ptr = (struct node*)malloc(sizeof (struct node));
int item;
printf(“Input the element for inserting :\n”);
scanf(“%d”,&item);
prt-> info = item;
ptr->link = NULL;
if (front == NULL) /* queue is empty*/
front = ptr;
else
rear->link = ptr;
rear = ptr;
}
void delete( )
{
struct node *ptr;
if (front == NULL)
{
printf(“Queue is underflow \n”) ;
return;
}
if (front == rear) {
Data Structure 2–33 A (CS/IT-Sem-3)
free(front);
rear = NULL;
}
else
{
ptr = front;
front = ptr->link;
free (ptr);
}
}
void display( )
{
struct node *ptr;
ptr = front;
if (front == NULL)
printf(“Queue is empty\n”);
else
{
printf(“\n Elements in the Queue are :\n”);
while(ptr != NULL)
{
printf(“%d\n”, ptr->info);
ptr = ptr->link;
}
printf(“\n”);
}
}
Answer
Implementation of circular queue using array :
Refer Q. 2.29, Page 2–29A, Unit-2.
Function to create circular queue :
void Queue :: enQueue(int value)
{
2–34 A (CS/IT-Sem-3) Stacks and Queues
Questions-Answers
Answer
1. In a dequeue, both insertion and deletion operations are performed at
either end of the queues. That is, we can insert an element from the
rear end or the front end. Also deletion is possible from either end.
Front Rear
Insertion Insertion
Deletion Deletion
Insertion
Deletion
Deletion
(a) Input-restricted dequeue
Front Rear
Insertion
Insertion
Deletion
(b) Output-restricted dequeue
Fig. 2.32.2.
2–36 A (CS/IT-Sem-3) Stacks and Queues
Answer
1. A priority queue is a data structure in which each element has been
assigned a value called the priority of the element and an element can
be inserted or deleted not only at the ends but at any position on the
queue.
2. A priority queue is a collection of elements such that each element has been
assigned an explicit or implicit priority and such that the order in which
elements are deleted and processed comes from the following rules :
a. An element of higher priority is processed before any element of
lower priority.
b. Two elements with the same priority are processed to the order in
which they were inserted to the queue.
Types of priority queues are :
1. Ascending priority queue : In ascending priority queue, elements
can be inserted in an order. But, while deleting elements from the
queue, always a small element to be deleted first.
2. Descending priority queue : In descending priority queue, elements
are inserted in any order but while deleting elements from the queue
always a largest element to be deleted first.
Applications of priority queue :
1. The typical example of priority queue is scheduling the jobs in operating
system. Typically operating system allocates priority to jobs. The jobs
are placed in the queue and position 1 of the job in priority queue
determines their priority.
2. In network communication, to manage limited bandwidth for
transmission, the priority queue is used.
3. In simulation modelling, to manage the discrete events the priority
queue is used.
Data Structure 3–1 A (CS/IT-Sem-3)
3 Searching and
Sorting
CONTENTS
Part-1 : Searching : Concept of ................................ 3–2A to 3–4A
Searching, Sequential
Search, Index Sequential
Search, Binary Search
Questions-Answers
Answer
1. Searching is the process of finding the location of given element in the
linear array.
2. The search is said to be successful if the given element is found, i.e., the
element does exists in the array; otherwise unsuccessful.
3. There are two searching techniques :
a. Linear search (sequential) b. Binary search
4. The algorithm which we choose depends on organization of the array
elements.
5. If the elements are in random order, then we have to use linear search
technique, and if the array elements are sorted, then it is preferable to
use binary search.
Answer
Sequential search :
1. In sequential (or linear) search, each element of an array is read one-
by-one sequentially and it is compared with the desired element. A
search will be unsuccessful if all the elements are read and the desired
element is found.
2. Linear search is the least efficient search technique among other search
techniques.
3. It is used when the records are stored without considering the order or
when the storage medium lacks the direct access facility.
4. It is the simplest way for finding an element in a list.
5. It searches the elements sequentially in a list, no matter whether list is
sorted or unsorted.
a. In case of sorted list in ascending order, the search is started from
1st element and continued until desired element is found or the
element whose value is greater than the value being searched.
Data Structure 3–3 A (CS/IT-Sem-3)
Answer
LINEAR(DATA, N, ITEM, LOC)
Here DATA is a linear array with N elements, and ITEM is a given item of
information. This algorithm finds the location LOC of ITEM in DATA, or sets
LOC := 0 if the search is unsuccessful.
1. [Insert ITEM at the end of DATA] Set DATA[N + 1] := ITEM
2. [Initialize counter] Set LOC := 1
3. [Search for ITEM]
Repeat while DATA[LOC] ITEM
Set LOC := LOC + 1
[End of loop]
4. [Successful?] If LOC = N + 1, then : Set LOC := 0
5. Exit
Analysis of linear search :
Best case : Element occur at first position. Time complexity is O(1).
Worst case : Element occur at last position. Time complexity is O(n).
Answer
Binary search (A, n, item, loc)
Let A is an array of ‘n’ number of items, item is value to be searched.
3–4 A (CS/IT-Sem-3) Searching and Sorting
Answer
Questions-Answers
Answer
1. Hashing is a technique that is used to uniquely identify a specific object
from a group of similar objects.
2. Hashing is the transformation of a string of characters into a usually
shorter fixed-length value or key that represents the original string.
3. In hashing, large keys are converted into small keys by using hash
functions.
4. The values are then stored in a data structure called hash table.
5. The task of hashing is to distribute entries (key/value pairs) uniformly
across an array.
6. Each element is assigned a key (converted key). By using that key we
can access the element in O(1) time.
7. Using the key, the algorithm (hash function) computes an index that
suggests where an entry can be found or inserted.
8. Hashing is used to index and retrieve items in a database because it is
faster to find the item using the shorter hashed key than to find it
using the original value.
9. The element is stored in the hash table where it can be quickly retrieved
using hashed key which is defined by
Hash Key = Key Value % Number of Slots in the Table
Que 3.7. Discuss types of hash functions.
Answer
Types of hash functions :
a. Division method :
1. Choose a number m larger than the number n of key in K. (The
number m is usually chosen to be a prime number or a number
without small divisors, since this frequently minimizes the number
of collisions.)
2. The hash function H is defined by :
H(k) = k (mod m) or H(k) = k (mod m) + 1
3. Here k (mod m) denotes the remainder when k is divided by m.
4. The second formula is used when we want the hash addresses to
range from 1 to m rather than from 0 to m – 1.
b. Midsquare method :
1. The key k is squared.
2. The hash function H is defined by : H(k) = l
where l is obtained by deleting digits from both end of k2.
3. We emphasize that the same positions of k2 must be used for all of
the keys.
c. Folding method :
1. The key k is partitioned into a number of parts, k1, .... , kr, where
each part, except possibly the last, has the same number of digits as
the required address.
3–6 A (CS/IT-Sem-3) Searching and Sorting
2. Then the parts are added together, ignoring the last carry i.e.,
H(k) = k1 + k2 + .... + kr
where the leading-digit carries, if any, are ignored.
4. Now truncate the address upto the digit based on the size of hash table.
Answer
Collision :
1. Collision is a situation which occur when we want to add a new record R with
key k to our file F, but the memory location address H(k) is already occupied.
2. A collision occurs when more than one keys map to same hash value in
the hash table.
Collision resolution technique :
Hashing with open addressing :
1. In open addressing, all elements are stored in the hash table itself.
2. While searching for an element, we systematically examine table slots
until the desired element is found or it is clear that the element is not in
the table.
3. Thus, in open addressing, the load factor can never exceed 1.
4. The process of examining the locations in the hash table is called probing.
5. Following are techniques of collision resolution by open addressing :
a. Linear probing :
i. Given an ordinary hash function h : U [0, 1, ....., m – 1], the
method of linear probing uses the hash function.
h (k, i) = (h (k) + i) mod m
where ‘m’ is the size of the hash table and h (k) = k mod m
(basic hash function).
b. Quadratic probing :
i. Suppose a record R with key k has the address H(k) = h then
instead of searching the locations with address h, h + 1,
h + 2, ....., we linearly search the locations with addresses
h, h + 1, h + 4, h + 9, ......., h + i2.
ii. Quadratic probing uses a hash function of the form
h (k, i) = (h (k) + c1i + c2i2) mod m
where (as in linear probing) h is an auxiliary hash function, c1
and c2 0 are auxiliary constants, and i = 0, 1, ....., m – 1.
c. Double hashing :
i. Double hashing is one of the best methods available for open
addressing because the permutations produced have many of
the characteristics of randomly chosen permutations.
Data Structure 3–7 A (CS/IT-Sem-3)
Answer
Hashing : Refer Q. 3.6, Page 3–4A, Unit-3.
Collision : Refer Q. 3.8, Page 3–6A, Unit-3.
Advantages of hashing over other search techniques :
1. The main advantage of hash tables over other table data structures is
speed. This advantage is more apparent when the number of entries is
large (thousands or more).
2. Hash tables are particularly efficient when the maximum number of
entries can be predicted in advance, so that the bucket array can be
allocated once with the optimum size and never resized.
3. If the set of key-value pairs is fixed and known ahead of time (so insertions
and deletions are not allowed), one may reduce the average lookup cost
by a careful choice of the hash function, bucket table size, and internal
data structures.
Disadvantages of hashing over other search techniques :
1. Hash tables can be more difficult to implement than self-balancing binary
search trees. Choosing an effective hash function for a specific application
is more an art than a science. In open-addressed hash tables it is fairly
easy to create a poor hash function.
3–8 A (CS/IT-Sem-3) Searching and Sorting
2. The cost of a good hash function can be significantly higher than the
inner loop of the lookup algorithm for a sequential list or search tree.
3. Hash tables are not effective when the number of entries is very small.
For certain string processing applications, such as spell-checking, hash
tables may be less efficient than trees, finite automata, or arrays.
4. If each key is represented by a small enough number of bits, then,
instead of a hash table, one may use the key directly as the index into an
array of values.
Que 3.10. Write short notes on garbage collection.
Answer
1. When some memory space becomes reusable due to the deletion of a
node from a list or due to deletion of entire list from a program then we
want the space to be available for future use.
2. One method to do this is to immediately reinsert the space into the free-
storage list. This is implemented in the linked list.
3. This method may be too time consuming for the operating system of a
computer.
4. In another method, the operating system of a computer may periodically
collect all the deleted space onto the free storage list. This type of
technique is called garbage collection.
5. Garbage collection usually takes place in two steps. First the computer
runs through all lists, tagging those cells which are currently in use and
then the computer runs through the memory, collecting all untagged
space onto the free storage list.
6. The garbage collection may take place when there is only some
minimum amount of space or no space at all left in the free storage list
or when the CPU is idle and has time to do the collection.
Que 3.11. Write the conditions when collision occurs in hashing.
Describe any collision detection algorithm in brief.
Answer
Condition when collision occurs : Refer Q. 3.8, Page 3–6A, Unit-3.
Collision detection algorithm :
a. One of the collision detection algorithms is grid based algorithm.
b. In this algorithm, grids are space-filling.
c. Each cell or voxel (volume pixel) has a list of objects which intersects it.
d. The uniform grid is used to determine which objects are near to an
object by examining object-lists of the cells the object overlaps.
e. Intersections for a given object are found by going through the object
lists for all voxels containing the object, performing intersection tests
against objects on those lists.
Data Structure 3–9 A (CS/IT-Sem-3)
Questions-Answers
Answer
1. In insertion sort, we pick up a particular value and then insert it at the
appropriate place in the sorted sublist, i.e., during kth iteration the element
a[k] is inserted in its proper place in the sorted sub-array a[1], a[2], a[3] ....
a[k – 1].
2. This task is accomplished by comparing a[k] with a[k – 1], a[k – 2],
a[k – 3] and so on until the first element a[j] such that a[j] a[k] is found.
3. Then each of the elements a[k – 1], a[k – 2], a[j + 1] are moved one position up and
then element a[k] is inserted in [j + 1]st position in the array.
Insertion-Sort (A)
1. for j 2 to length[A]
2. do key A[j] /*Insert A[j] into the sorted sequence A[1....j – 1].*/
3. i j – 1
4. while i > 0 and A[i] > key
5. do A[i + 1] A[i]
6. ii–1
7. A[i + 1] key
Analysis of insertion sort :
Complexity of best case isO(n)
Complexity of average case is O(n2)
Complexity of worst case is O(n2)
3–10 A (CS/IT-Sem-3) Searching and Sorting
Answer
1. In selection sort we repeatedly find the next largest (or smallest) element
in the array and move it to its final position in the sorted array.
2. We begin by selecting the largest element and moving it to the highest
index position.
3. We can do this by swapping the element at the highest index and the
largest element.
4. We then reduce the effective size of the array by one element and
repeat the process on the smaller sub-array.
5. The process stops when the effective size of the array becomes 1 (an
array of 1 element is already sorted).
Selection-Sort (A) :
1. n length[A]
2. for j 1 to n – 1
3. smallest j
4. for i j + 1 to n
5. if A [i] < A[smallest]
6. then smallest i
7. exchange(A[j], A[smallest])
Analysis of selection sort :
Complexity of best case is O(n2).
Complexity of average case is O(n2).
Complexity of worst case is O(n2).
Que 3.14. Discuss bubble sort.
Answer
1. Bubble sort is the simplest sorting algorithm that works by repeatedly
swapping the adjacent element if they are in wrong order.
2. Bubble sort procedure is based on following idea :
a. Suppose if the array contains n elements, then (n – 1) iterations are
required to sort this array.
b. The set of items in the array are scanned again and again and if any
two adjacent items are found to be out of order, they are reversed.
c. At the end of the first iteration, the lowest value is placed in the
first position.
d. At the end of the second iteration, the next lowest value is placed in
the second position and so on.
3. It is very efficient in large sorting jobs. For n data items, this method
requires n(n – 1)/2 comparisons.
Bubble-sort (A) :
1. for i 1 to length [A]
2. for j length[A] down to i + 1
Data Structure 3–11 A (CS/IT-Sem-3)
Quick Sort.
Questions-Answers
Que 3.15. Explain and give quick sort algorithm. Determine its
complexity.
Answer
1. Quick sort is a sorting algorithm that also uses the idea of divide and
conquer.
2. This algorithm finds the elements, called pivot, that partitions the array
into two halves in such a way that the elements in the left sub-array are
less than and the elements in the right sub-array are greater than the
partitioning element.
3. Then these two sub-arrays are sorted separately. This procedure is
recursive in nature with the base criteria.
Algorithm :
QUICK (A, N, BEG, END, LOC) :
1. [Initialize] Set LEFT := BEG, RIGHT := END and LOC := BEG
2. [Scan from RIGHT to LEFT]
a. Repeat while A [LOC] A [RIGHT] and LOC RIGHT
RIGHT := RIGHT – 1
[End of Loop]
b. If LOC = RIGHT, then : Return
c. If A [LOC] > A [RIGHT], then :
i. [Interchange A [LOC] and A [RIGHT]]
TEMP := A [LOC], A [LOC] := A [RIGHT],
A [RIGHT] = TEMP
ii. Set LOC := RIGHT
iii. Go to step 3
[End of if structure]
3. [Scan from LEFT to RIGHT]
a. Repeat while A [LEFT] A [LOC] and LEFT LOC :
3–12 A (CS/IT-Sem-3) Searching and Sorting
LEFT := LEFT + 1
[End of Loop]
b. If LOC = LEFT, then : Return,
c. If A [LEFT] > A [LOC], then
i. [Interchange A [LEFT] and A [LOC]]
TEMP := A [LOC], A [LOC] := A [LEFT],
A [LEFT] := TEMP
ii. Set LOC := LEFT
iii. Go to step 2
[End of if structure]
Quick sort : This algorithm sorts an array A with N elements.
1. [Initialize] Top := NULL
2. [PUSH boundary values of A onto stack when A has 2 or more elements]
If N > 1, then : TOP := TOP + 1, LOWER [1] := 1, UPPER [1] := N
3. Repeat steps 4 to 7 while TOP NULL
4. [POP sublist from stacks]
Set BEG := LOWER [TOP], END := UPPER [TOP],
TOP = TOP – 1
5. Call Quick (A, N, BEG, END, LOC)
6. [PUSH left sublist onto stack when it has 2 or more elements]
If BEG < LOC – 1 then :
TOP := TOP + 1, LOWER [TOP] := BEG,
UPPER [TOP] = LOC – 1
[End of if structure]
7. [PUSH right sublist onto stack when it has 2 or more elements]
If LOC + 1 < END, then :
TOP := TOP + 1, LOWER [TOP] := LOC + 1
UPPER [TOP] := END
[END of if structure]
[END of step 3 loop]
8. Exit
Analysis of quick sort :
Complexity of worst case is O(n2).
Complexity of best case is O(n log n).
Complexity of average case is O(n log n).
Answer
QUICK-SORT (A, p, r) :
1. If p < r then
2. q PARTITION (A, p, r)
3. QUICK-SORT (A, p, q – 1)
4. QUICK-SORT (A, q + 1, r)
PARTITION (A, p, r) :
1. x A[r]
2. i p – 1
Data Structure 3–13 A (CS/IT-Sem-3)
3. for j p to r – 1
4. do if A[j] x
5. then i i + 1
6. exchange A[i] A[j]
7. exchange A[i + 1] A[r]
8. return i + 1
Que 3.17. What is quick sort ? Sort the given values using quick
sort; present all steps/iterations :
38, 81, 22, 48, 13, 69, 93, 14, 45, 58, 79, 72 AKTU 2016-17, Marks 10
Answer
Quick sort : Refer Q. 3.15, Page 3–11A, Unit-3.
Numerical : A = 38, 81, 22, 48, 13, 69, 93, 14, 45, 58, 79, 72. Choose the pivot
element to be the element in position (left + right)/2.
During the partitioning process,
1. Elements strictly to the left of position lo are less than or equivalent to
the pivot element (69).
2. Elements strictly to the right of position hi are greater than the pivot
element. When lo and hi cross, we are done. The final value of hi is the
position in which the partitioning element ends up.
Swap pivot element with leftmost element lo = left + 1; hi = right;
Move hi left and lo right as far as we can; then swap A[lo] and A[hi], and
move hi and lo one more position.
lo hi hi hi
69 81* 22 48 13 38 93 14 45 58* 79* 72*
Repeat above
lo lo lo lo lo hi
69 58 22* 48* 13* 38* 93* 14 45* 81 79 72
Repeat above until hi and lo cross; then hi is the final position of the
pivot element, so swap A[hi] and A[left].
hi
lo lo
69 58 22 48 13 38 45 14** 93* 81 79 72
hi
14 58 22 48 13 38 45 69 93 81 79 72
quicksort ( A, 1, 12)
38 81 22 48 13 69 93 14 45 58 79 72
14 58 22 48 13 38 45 69 93 81 79 72
Fig. 3.17.1.
Que 3.18. Write algorithm for quick sort. Trace your algorithm
on the following data to sort the list: 2, 13, 4, 21, 7, 56, 51, 85, 59, 1, 9, 10.
How the choice of pivot elements affects the efficiency of algorithm.
AKTU 2018-19, Marks 07
Answer
Quick sort algorithm : Refer Q. 3.16, Page 3–12A, Unit-3.
Numerical :
1 2 3 4 5 6 7 8 9 10 11 12
2 13 4 21 7 56 51 85 59 1 9 10
Here p = 1, r = 12
x= A[12] = 10
i= p–1=0
j= 1+0=1
Now, j= 1 and i = 0
Data Structure 3–15 A (CS/IT-Sem-3)
A[1] = 2 10 (True)
then i = 0 + 1 = 1 and A[1] A[1]
Now, j = 2 and i = 1
A[2] = 13 and 13 10 (False)
So, j= 3 i=1
A[3] = 4 and 4 10 (True)
then, i= 1 + 1 = 2 and A[2] A[3]
1 2 3 4 5 6 7 8 9 10 11 12
i.e., 2 4 13 21 7 56 51 85 59 1 9 10
Now, j = 4 and i = 2
A[4] = 21 and 21 10 (False)
j= 5 and i = 2
A[5] = 7 10 (True)
then, i= 2 + 1 = 3 and A[3] A[5]
1 2 3 4 5 6 7 8 9 10 11 12
i.e., 2 4 7 21 13 56 51 85 59 1 9 10
Now, j = 6 and i = 3
A[6] = 56 and 56 10
So, j = 7 and i = 3
A[7] = 51 and 51 10
j = 8 and i = 3
A[8] = 85 and 85 10
j = 9 and i = 3
A[9] = 59 and 59 10
j= 10 and i = 3
A[10] = 1 10 (True)
then, i= 3 + 1 = 4 and A[4] A[10]
1 2 3 4 5 6 7 8 9 10 11 12
i.e., 2 4 7 1 13 56 51 85 59 21 9 10
j = 11 and i = 4
A[11] = 9 10 (True)
i = 4 + 1 = 5 and A[5] A[11]
1 2 3 4 5 6 7 8 9 10 11 12
i.e., 2 4 7 1 9 56 51 85 59 21 13 10
A[6] A[12]
Partitioning complete, return value of q :
1 2 3 4 5 6 7 8 9 10 11 12
2 4 7 1 9 10 56 51 85 59 21 13
3–16 A (CS/IT-Sem-3) Searching and Sorting
Quicksort ( A, 1, 12)
2, 4, 7, 1, 9, 10, 56, 51, 85, 59, 21, 13
Que 3.19. Use quick sort algorithm to sort 15, 22, 30, 10, 15, 64, 1, 3,
9, 2. Is it a stable sorting algorithm? Justify.
AKTU 2017-18, Marks 07
Answer
1 2 3 4 5 6 7 8 9 10
Let A [ ] = 15 22 30 10 15 64 1 3 9 2
Here p = 1, r = 10
Data Structure 3–17 A (CS/IT-Sem-3)
x = A[10] i.e., x = 2
i = p – 1 i.e., i = 0
j = 1 to 9
Now, j = 1 and i = 0
A[j] = A[1] = 15 and 15 2
So, j = 2 and i = 0
A[2] = 22 2 (False)
Now, j = 3 and i = 0
A[3] = 30 2 (False)
j = 4 and i = 0
A[4] = 10 2 (False)
j= 5
A[5] = 15 2 (False)
j= 6
A[6] = 64 2 (False)
j= 7
A[7] = 1 2 (True)
i= 0+1=1
A[1] A[7]
1 2 3 4 5 6 7 8 9 10
i.e., 1 22 30 10 15 64 15 3 9 2
j= 8 and i = 1
A[8] = 3 2 (False)
j= 9 and i = 1
A[9] = 9 2 (False)
then, A[1 + 1] A[r]
A[2] A[10]
q 2
1 2 3 4 5 6 7 8 9 10
i.e., 1 2 30 10 15 64 15 3 9 22
QUICK SORT (A, 1, 1)
1 2
1 2
QUICK SORT (A, 3, 10)
3 4 5 6 7 8 9 10
30 10 15 64 15 3 9 22
Here p= 3, r = 10
x= A[10] = 22
i= 3–1=2
j= 3 to 9; j = 3 and i = 2
A[3] = 30 22 (False)
j= 4 and i = 2
A[4] = 10 22 (True)
i= 2 + 1 = 3 and A[3] A[4]
3–18 A (CS/IT-Sem-3) Searching and Sorting
3 4 5 6 7 8 9 10
i.e., 10 30 15 64 15 3 9 22
j = 5 and i = 3
A[5] = 15 22 (True)
i = 3 + 1 = 4 and A[4] A[5]
3 4 5 6 7 8 9 10
10 15 30 64 15 3 9 22
Similarly
j = 7, i = 4
A[7] = 15 22 (True)
i = 4 + 1 = 5 and A[5] A[7]
3 4 5 6 7 8 9 10
i.e., 10 15 15 64 15 3 9 22
Similarly, we get another pivot element
10 15 15 3 9 22 64 30
Thus, this is a stable algorithm.
Merge Sort.
Questions-Answers
Que 3.20. Describe two way merge sort method. Explain the
complexities of merge sort method.
Answer
Merge sort :
a. Merge sort is a sorting algorithm that uses the idea of divide and conquer.
b. This algorithm divides the array into two halves, sorts them separately
and then merges them.
c. This procedure is recursive, with the base criteria that the number of
elements in the array is not more than 1.
MERGE_SORT (a, p, r) :
1. if p < r
2. then q (p + r)/2
3. MERGE-SORT (A, p, q)
4. MERGE-SORT (A, q + 1, r)
Data Structure 3–19 A (CS/IT-Sem-3)
5. MERGE (A, p, q, r)
MERGE (A, p, q, r) :
1. n1 = q – p + 1
2. n2 = r – q
3. Create arrays L [1 .........n1 + 1] and
R [1......n2 + 1]
4. for i = 1 to n1
do
L[i] = A [p + i – 1]
endfor
5. for j = 1 to n2
do
R[j] = A[q + j]
endfor
6. L[n1 + 1] = , R[n2 + 1] =
7. i = 1, j = 1
8. for k = p to r
do
if L[i] R[j]
then A[k] L[i]
i=i+1
else A[k] = R[j]
j=j+1
endif
endfor
9. exit
Complexity of merge sort algorithm :
1. Let f(n) denote the number of comparisons needed to sort an
n-element array A using the merge sort algorithm.
2. The algorithm requires at most log n passes.
3. Moreover, each pass merges a total of n elements, and by the discussion
on the complexity of merging, each pass will require at most n
comparisons.
4. Accordingly, for both the worst case and average case,
f(n) n log n
5. This algorithm has the same order as heap sort and the same average
order as quick sort.
6. The main drawback of merge sort is that it requires an auxiliary array
with n elements.
7. Each of the other sorting algorithms requires only a finite number of
extra locations, which is independent of n.
8. The results are summarized in the following table :
Algorithm Worst case Average case Extra memory
Merge sort n log n = O(n log n) n log n = O(n log n) O(n)
3–20 A (CS/IT-Sem-3) Searching and Sorting
Answer
Merge sorting : Refer Q. 3.20, Page 3–18A, Unit-3.
Numerical :
10, 25, 16, 5, 35, 48, 8
1. Divide first half 10, 25, 16, 5 35, 48, 8
2. Consider the first half : 10, 25, 16, 5 again divide into two sub- arrays
10 , 25 16 , 5
10, 25 5, 16
5, 10, 16, 25
3. Consider the second half : 35, 48, 5 again divide into two sub-arrays
35 , 48 8
35, 48 8
8, 35, 48
Answer
Complexity : Refer Q. 3.20, Page 3–18A, Unit-3.
Data Structure 3–21 A (CS/IT-Sem-3)
Function :
void merge (int low, int mid, int high)
{
int temp [MAX] ;
int i = low;
int j = mid + 1;
int k = low;
while ((i <= mid) && (j <= high))
{
if (array [i] <= array [j ] )
temp [k++] = array [i++];
else
temp [k++] = array [j++] ;
}
while (i <= mid)
temp [k++] = array [i++];
while (j <= high)
temp [k++] = array [j++] ;
for (i = low; i <= high; i++)
array [i] = temp [i];
}
void merge_sort (int low, int high)
{
int mid;
if (low != high)
{
mid = (low + high) / 2;
merge_sort (low, mid);
merge_sort (mid + 1, high);
merge (low, mid, high);
}
}
Questions-Answers
OR
Explain heap sort. AKTU 2017-18, Marks 3.5
Answer
1. Heap sort finds the largest element and puts it at the end of array, then
the second largest item is found and this process is repeated for all other
elements.
2. The general approach of heap sort is as follows :
a. From the given array, build the initial max heap.
b. Interchange the root (maximum) element with the last element.
c. Use repetitive downward operation from root node to rebuild the
heap of size one less than the starting.
d. Repeat step (a) and (b) until there are no more elements.
Analysis of heap sort :
Complexity of heap sort for all cases is O(n log2 n).
MAX-HEAPIFY (A, i) :
1. i left [i]
2. r right [i]
3. if l heap-size [A] and A[l] > A[i]
4. then largest l
5. else largest i
6. if r heap-size [A] and A[r] > A [largest]
7. then largest r
8. if largest i
9. then exchange A[i] A[largest]
10. MAX-HEAPIFY [A, largest]
HEAP-SORT(A) :
1. BUILD-MAX-HEAP (A)
2. for i length [A] down to 2
3. do exchange A[1] A[i]
4. heap-size [A] heap-size [A] – 1
5. MAX-HEAPIFY (A, 1)
Answer
1. Radix sort is a small method that many people uses when alphabetizing
a large list of names (here Radix is 26, 26 letters of alphabet).
2. Specifically, the list of name is first sorted according to the first letter of
each name, i.e., the names are arranged in 26 classes.
3. Intuitively, one might want to sort numbers on their most significant
digit.
Data Structure 3–23 A (CS/IT-Sem-3)
Q. 5. What is quick sort ? Sort the given values using quick sort;
present all steps/iterations :
38, 81, 22, 48, 13, 69, 93, 14, 45, 58, 79, 72
Ans. Refer Q. 3.17.
Q. 7. Use quick sort algorithm to sort 15, 22, 30, 10, 15, 64, 1, 3, 9, 2.
Is it a stable sorting algorithm? Justify.
Ans. Refer Q. 3.19.
Data Structure 4–1 A (CS/IT-Sem-3)
4 Graphs
CONTENTS
Part-1 : Graphs : Terminology ................................ 4–2A to 4–4A
used with Graphs
Questions-Answers
Answer
1. A graph is a non-linear data structure consisting of nodes and edges.
2. A graph is a finite sets of vertices (or nodes) and set of edges which
connect a pair of nodes.
Types of graph :
1. Undirected graph :
a. If the pair of vertices is unordered then graph G is called an
undirected graph.
b. That means if there is an edge between v1 and v2 then it can be
represented as (v1, v2) or (v2, v1) also. It is shown in Fig. 4.1.1.
v4 v3
v1 v2
Fig. 4.1.1.
2. Directed graph :
a. If the pair of vertices is ordered then graph G is called directed
graph.
b. That is, a directed graph or digraph is a graph which has ordered
pair of vertices (v1, v2) where v1 is the tail and v2 is the head of the
edge.
c. If the graph is directed then the line segments of arcs have arrow
heads indicating the direction. It is shown in Fig. 4.1.2.
v1 v2
v4 v3
Fig. 4.1.2.
3. Weighted graph : A graph is said to be a weighted graph if all the edges
in it are labelled with some numbers. It is shown in the Fig. 4.1.3.
Data Structure 4–3 A (CS/IT-Sem-3)
B 7 C
2 2
A 6 D
3 1
F 4 E
Fig. 4.1.3.
4. Simple graph : A graph or directed graph which does not have any self-
loop or parallel edges is called a simple graph.
5. Multi-graph : A graph which has either a self-loop or parallel edges or
both is called a multi-graph.
6. Complete graph :
a. A graph is complete graph if each vertex is adjacent to every other
vertex in graph or there is an edge between any pair of nodes in the
graph.
b. An undirected complete graph will contain n(n – 1)/2 edges.
7. Regular graph :
a. A graph is regular if every node is adjacent to the same number of
nodes.
b. Here every node is adjacent to 3 nodes.
1 2
3 4
Fig. 4.1.4.
2 3 2 3
(a) Connected graph (b) Not connected graph
Fig. 4.1.5.
4–4 A (CS/IT-Sem-3) Graphs
10. Acyclic graph : If a graph (digraph) does not have any cycle then it is
called as acyclic graph.
11. Cyclic graph : A graph that has cycles is called a cyclic graph.
12. Biconnected graph : A graph with no articulation points is called a
biconnected graph.
Applications of graph :
1. Graph is a non-linear data structure and is used to present various
operations and algorithms.
2. Graphs are used for topological sorting.
3. Graphs are used to find shortest paths.
4. They are required to minimize some aspect of the graph, such as distance
among all the vertices in the graph.
Answer
Graph : Refer Q. 4.1, Page 4–2A, Unit-4.
Various terminologies used in graphs are :
1. Self loop : If there is an edge whose starting and end vertices are same
that is (v2, v2) is an edge then it is called a self loop or simply a loop.
2. Parallel edges : A pair of edges e and e of G are said to be parallel iff
they are incident on precisely the same vertices.
3. Adjacent vertices : A vertex u is adjacent to (or the neighbour of)
other vertex v if there is an edge from u to v.
4. Incidence : In an undirected graph the edge (u, v) is incident on vertices
u and v. In a digraph the edge (u, v) is incident from node u and is
incident to node v.
5. Degree of vertex : The degree of a vertex is the number of edges
incident to that vertex. In an undirected graph, the number of edges
connected to a node is called the degree of that node.
Questions-Answers
Answer
Two types of graph representation are as follows :
1. Matrix representation : Matrices are commonly used to represent
graphs for computer processing. Advantages of representing the graph
in matrix lies on the fact that many results of matrix algebra can be
readily applied to study the structural properties of graph from an
algebraic point of view.
a. Adjacency matrix :
i. Representation of undirected graph : The adjacency matrix
of a graph G with n vertices and no parallel edges is a n × n
matrix A = [aij] whose elements are given by
aij = 1, if there is an edge between ith and jth vertices
= 0, if there is no edge between them
ii. Representation of directed graph : The adjacency matrix
of a digraph D, with n vertices is the matrix
A = [aij]n×n in which
aij = 1 if arc (vi, vj) is in D
= 0 otherwise
For example : Representation of following undirected and
directed graph is :
v1 v4 v1 v4
A= B=
v2 v3 v2 v3
Fig. 4.3.1. Fig. 4.3.2.
v1 v2 v3 v4 v1 v2 v3 v4
v1 0 1 1 1 v1 0 0 0 1
v2 1 0 1 0 v2 1 0 1 0
A= B=
v3 1 1 0 1 v3 0 0 0 1
v4 1 0 1 0 v4 0 1 0 0
b. Incidence matrix
i. Representation of undirected graph : Consider a
undirected graph G = (V, E) which has n vertices and m edges
all labelled. The incidence matrix I(G) = [bij], is then n × m
matrix, where
bij = 1 when edge ej is incident with vi
= 0 otherwise
ii. Representation of directed graph : The incidence matrix
I(D) = [bij] of digraph D with n vertices and m edges is the
n × m matrix in which.
bij = 1 if arc j is directed away from vertex vi
= –1 if arc j is directed towards vertex vi
=0 otherwise.
Find the incidence matrix to represent the graph shown in
Fig. 4.3.3.
4–6 A (CS/IT-Sem-3) Graphs
v1 e1 v2
e4 e5 e2
v4 e3 v3
Fig. 4.3.3.
The incidence matrix of the digraph of Fig. 4.3.3 is
1 0 0 1 1
1 1 0 0 0
I(D) =
0 1 1 0 1
0 0 1 1 0
2. Linked representation :
i. In linked representation, the two nodes structures are used :
a. For non-weighted graph : INFO Adj-list
4 5 6
Fig. 4.3.4.
iv. The adjacency list representation of this graph.
1 2 4 /
2 5 /
3 6 5 /
4 2 /
5 4 /
6 6 /
Fig. 4.3.5.
Data Structure 4–7 A (CS/IT-Sem-3)
Answer
1. Adjacency multilist representation maintains the lists as multilists, that
is, lists in which nodes are shared among several lists.
2. For each edge there will be exactly one node, but this node will be in two
lists i.e., the adjacency lists for each of the two nodes, it is incident to.
The node structure now becomes :
Mark vertex 1 vertex 2 path 1 path 2
where mark is a one bit mark field that may be used whether or not the
edge has been examined. The declarations in C are :
#define n 20
typedef struct edge {BOOLEAN mark;
int vertex1, vertex2;
NEXTEDGE path1, path2;
}*NEXTEDGE;
NEXTEDGE headnode [n];
Questions-Answers
Answer
Traversing a graph :
i. Graph is represented by its nodes and edges, so traversal of each node is
the traversing in graph.
ii. There are two standard ways of traversing a graph.
iii. One way is called a breadth first search, and the other is called a depth
first search.
iv. During the execution of our algorithms, each node N of G will be in one
of three states, called the status of N, as follows :
Status = 1 (Ready state). The initial state of the node N.
Status = 2 (Waiting state). The node N is on the queue or
stack, waiting to be processed.
Status = 3 (Processed state). The node N has been
processed.
4–8 A (CS/IT-Sem-3) Graphs
1. Breadth First Search (BFS) : The general idea behind a breadth first
search beginning at a starting node A is as follows :
a. First we examine the starting node A.
b. Then, we examine all the neighbours of A, and so on.
c. We need to keep track of the neighbours of a node, and that no
node is processed more than once.
d. This is accomplished by using a queue to hold nodes that are waiting
to be processed, and by using a field STATUS which tells us the
current status of any node.
Algorithm : This algorithm executes a breadth first search on a graph G
beginning at a starting node A.
i. Initialize all nodes to ready state (STATUS=1).
ii. Put the starting node A in queue and change its status to the waiting
state (STATUS = 2).
iii. Repeat steps (iv) and (v) until queue is empty.
iv. Remove the front node N of queue. Process N and change the status of
N to the processed state (STATUS = 3).
v. Add to the rear of queue all the neighbours of N that are in the ready
state (STATUS=1) and change their status to the waiting state
(STATUS = 2).
[End of loop]
vi. End.
2. Depth First Search (DFS) : The general idea behind a depth first
search beginning at a starting node A is as follows :
a. First, we examine the starting node A.
b. Then, we examine each node N along a path P which begins at A;
that is, we process neighbour of A, then a neighbour of neighbour
of A, and so on.
c. This algorithm uses a stack instead of queue.
Algorithm :
i. Initialize all nodes to ready state (STATUS = 1).
ii. Push the starting node A onto stack and change its status to the waiting
state (STATUS = 2).
iii. Repeat steps (iv) and (v) until queue is empty.
iv. Pop the top node N of stack, process N and change its status to the
processed state (STATUS = 3).
v. Push onto stack all the neighbours of N that are still in the ready state
(STATUS = 1) and change their status to the waiting state
(STATUS = 2).
[End of loop]
vi. End.
2 10
7
14 3
1 5
3
8 12
1 4
7 12 2
5
4 20
6
6
Fig. 4.6.1.
AKTU 2014-15, Marks 10
Answer
DFS : Refer Q. 4.5, Page 4–7A, Unit-4.
Numerical : Adjacency list of the given graph :
1 2, 7
23
3 5, 4, 1
46
54
6 2, 5, 1
7 3, 6
1. Initially set STATUS = 1 for all vertex
2. Push 1 onto stack and set their STATUS = 2
1
3. Pop 1 from stack, change its STATUS = 1 and
Push 2, 7 onto stack and change their STATUS = 2; DFS = 1
7
2
4. Pop 7 from stack, Push 3, 6; DFS = 1, 7
6
3
2
5. Pop 6 from stack, Push 5; DFS = 1, 7, 6
5
3
2
6. Pop 5 from stack, Push 4; DFS = 1, 7, 6, 5
4
3
2
7. Pop 4 from stack; DFS = 1, 7, 6, 5, 4
3
2
4–10 A (CS/IT-Sem-3) Graphs
2
9. Pop 2 from stack; DFS = 1, 7, 6, 5, 4, 3
Now, the stack is empty, so the depth first traversal of a given graph is 1, 7,
6, 5, 4, 3.
Que 4.7. Implement BFS algorithm to find the shortest path from
node A to J.
A
F C B
E G
D
J K
Fig. 4.7.1.
OR
Explain in detail about the graph traversal techniques with
suitable example. AKTU 2018-19, Marks 07
Answer
Following are the two traversal techniques :
1. Depth First Search (DFS) : Refer Q. 4.5, Page 4–7A, Unit-4.
Example : Refer Q. 4.6, Page 4–8A, Unit-4.
2. Breadth First Search (BFS) : Refer Q. 4.5, Page 4–7A, Unit-4.
To find the shortest path from node A to node J
Adjacency list of the graph is :
A : F, C, B
B : G, C
C : F
D : C
E : D, C, J
F : D
G : C, E
J : D, K
K : E, G
a. Initially set STATUS=1 for all vertex.
b. Now add ‘A’ to Queue and set STATUS = 2
Queue: A
c. Remove A from Queue and set STATUS = 3
and add F, C, B in Queue and change their STATUS = 2
BFS = A Queue: F, C, B
Data Structure 4–11 A (CS/IT-Sem-3)
Answer
Various types of traversing techniques are :
1. Breadth First Search (BFS) 2. Depth First Search (DFS)
Importance of BFS :
1. It is one of the single source shortest path algorithms, so it is used to
compute the shortest path.
2. It is also used to solve puzzles such as the Rubik’s Cube.
3. BFS is not only the quickest way of solving the Rubik’s Cube, but also
the most optimal way of solving it.
Application of BFS : Breadth first search can be used to solve many problems
in graph theory, for example :
1. Copying garbage collection.
2. Finding the shortest path between two nodes u and v, with path length
measured by number of edges (an advantage over depth first search).
3. Ford-Fulkerson method for computing the maximum flow in a flow
network.
4. Serialization/Deserialization of a binary tree vs serialization in sorted
order, allows the tree to be re-constructed in an efficient manner.
5. Construction of the failure function of the Aho-Corasick pattern
matcher.
6. Testing bipartiteness of a graph.
Importance of DFS : DFS is very important algorithm as based upon DFS,
there are O(V + E)-time algorithms for the following problems :
1. Testing whether graph is connected.
2. Computing a spanning forest of G.
3. Computing the connected components of G.
4. Computing a path between two vertices of G or reporting that no such
path exists.
5. Computing a cycle in G or reporting that no such cycle exists.
4–12 A (CS/IT-Sem-3) Graphs
Answer
Connected component : Connected component of an undirected graph is
a sub-graph in which any two vertices are connected to each other by paths,
and which is connected to no additional vertices in the super graph.
Strongly connected component : A directed graph is strongly connected
if there is a path between all pairs of vertices. A strong component is a
maximal subset of strongly connected vertices of subgraph.
Kosaraju’s algorithm is used to find strongly connected components in a
graph.
Kosaraju’s algorithm :
1. For each vertex u of the graph, mark u as unvisited. Let L be empty.
2. For each vertex u of the graph do Visit(u), where Visit(u) is the recursive
subroutine. If u is unvisited then :
a. Mark u as visited.
b. For each out-neighbour v of u, do Visit(v).
c. Prepend u to L. Otherwise do nothing.
3. For each element u of L in order, do Assign(u, u) where Assign (u, root)
is the recursive subroutine. If u has not been assigned to a component
then :
a. Assign u as belonging to the component whose root is root.
b. For each in-neighbour v of u, do Assign (v, root).
Otherwise do nothing.
Questions-Answers
Answer
Spanning tree :
1. A spanning tree of an undirected graph is a sub-graph that is a tree
which contains all the vertices of graph.
2. A spanning tree of a connected graph G contains all the vertices and has
the edges which connect all the vertices. So, the number of edges will be
1 less than the number of nodes.
3. If graph is not connected, i.e., a graph with n vertices has edges less than
n – 1 then no spanning tree is possible.
4. A connected graph may have more than one spanning trees.
Minimum spanning tree :
1. In a weighted graph, a minimum spanning tree is a spanning tree that
has minimum weight than all other spanning trees of the same graph.
2. There are number of techniques for creating a minimum spanning tree
for a weighted graph but the most famous methods are Prim’s and
Kruskal’s algorithm.
Answer
First it chooses a vertex and then chooses an edge with smallest weight
incident on that vertex. The algorithm involves following steps :
Step 1 : Choose any vertex V1 of G.
Step 2 : Choose an edge e1 =V1V2 of G such that V2 V1 and e1 has smallest
weight among the edge e of G incident with V1.
Step 3 : If edges e1, e2, ......., ei have been chosen involving end points V1, V2,
............., Vi+1, choose an edge ei+1 = VjVk with Vj = {V1 ....... Vi+1} and
Vk {V1 ...........Vi+1} such that ei+1 has smallest weight among the
edges of G with precisely one end in {V1 ............... Vi+1}.
Step 4 : Stop after n – 1 edges have been chosen. Otherwise goto step 3.
Que 4.12. Define spanning tree. Find the minimal spanning tree
for the following graph using Prim’s algorithm.
2 19
6 4 3
9
12 25 17
8 5 1
21 13 1
7 5 2
Fig. 4.12.1.
AKTU 2014-15, Marks 10
4–14 A (CS/IT-Sem-3) Graphs
Answer
Spanning tree : Refer Q. 4.10, Page 4–13A, Unit-4.
Numerical :
1 2 3 4 5 6 7
1 – 1 9 – – – –
2 1 – 5 – 13 – –
3 9 5 – 19 17 – –
4 – – 19 – 25 2 –
5 – 13 17 25 – 12 21
6 – – – 2 12 – 8
7 – – – – 21 8 –
According to Prim’s algorithm, we choose vertex 1.
We choose edge (1, 2), since it has minimum value.
2 19
6 4 3
9
12 25 17
8 5 1
1
7 5 2
21 13
Now at vertex 2, we choose the edge (2, 3), since it has minimum value.
2 19
6 4 3
9
12 25 17
8 5 1
1
7 5 2
21 13
Now at vertex 3, we cannot choose edge (3, 1) because it will create a
cycle so we choose (3, 5).
2 19
6 4 3
9
17
8 25 5 1
12
1
7 5 2
21 13
Now at vertex 5, we choose the edge (5, 6) since it has minimum value.
2 19
6 4 3
9
8 25 17 5 1
12
1
7 5 2
21 13
Data Structure 4–15 A (CS/IT-Sem-3)
Now at vertex 6, we choose the edge (6, 7) since it has minimum value.
2 19
6 4 3
9
25 17
8 5 1
12
1
7 5 2
21 13
6 4 3
7 5 2
Since in spanning tree, the tree should cover all the vertices and should
not make cycle.
But in the above tree, 4 is remaining so the above asked question is
wrong. If we assume to remove the edge from {3, 5} then the spanning
tree is :
1 2 3 4 5 6 7
1 – 1 9 – – – –
2 1 – 5 – 13 – –
3 9 5 – 19 – – –
4 – – 19 – 25 2 –
5 – 13 17 25 – 12 21
6 – – – 2 12 – 8
7 – – – – 21 8 –
According to Prim’s algorithm, let’s choose vertex 1.
We choose edge {1, 2}, since it has minimum value.
2 19
6 4 3
9
12 25
8 5 1
1
7 5 2
21 13
Now at vertex 2, we choose the edge (2, 3), since it has minimum value.
2 19
6 4 3
9
12 25
8 5 1
1
7 5 2
21 13
4–16 A (CS/IT-Sem-3) Graphs
Now at vertex 3, we choose the edge (3, 4), since it has minimum value.
2 19
6 4 3
9
12 25
8 5 1
1
7 5 2
21 13
Now at vertex 4, we choose the edge (4, 6), since it has minimum value.
2 19
6 4 3
9
8 12 25 1
5
1
7 5 2
21 13
Now at vertex 6, we choose the edge (6, 7), since it has minimum value.
2 19
6 4 3
9
8 25 5 1
12
1
7 5 2
21 13
Now at vertex 7, we cannot choose the edge (7, 6), because we have
already traversed this edge these we choose (7, 5).
2 19
6 4 3
9
12 25
8 5 1
1
7 5 2
21 13
The spanning tree is
2 19
6 4 3
9
12 25
8 5 1
1
7 5 2
21 13
Data Structure 4–17 A (CS/IT-Sem-3)
12
A B 1
17 7
15 F 2 C
19 10
14 6
E D
Fig. 4.13.1.
Answer
Spanning tree : Refer Q. 4.10, Page 4–13A, Unit-4.
Numerical :
12
A B 1
17 7
15 F 2 C
19 10
14 6
E D
Let us take A as source node.
Now we look on weight
w(A, B) = 12, w(A, F) = 17, w(A, E) = 15
w(A, B) is smallest. Choose e = (AB)
12
A B 1
17 7
15 F 2 C
19 10
14 6
E D
Now we look on weight
w(B, F) = 7, w(B, D) = 2, w(B, C) = 1
w(B, C) is smallest choose e = (BC)
12
A B 1
17 7
15 F 2 C
19 10
14 6
E D
Now we look on weight
w(C, D) = 6
w(C, D) is smallest choose e = (CD)
4–18 A (CS/IT-Sem-3) Graphs
12
A B 1
17 7
15 F 2 C
19 10
14 6
E D
Now we look on weight
w(D, B) = 2, w(D, F) = 10, w(D, E) = 14
w(D, B) is smallest but forms a cycle
Discard it.
Now w(D, F) = 10 is smallest Choose e = (DF)
12
A B 1
17 7
15 F 2 C
19 10
14 6
E D
Now we look on weight
w(F, B) = 7, w(F, A) = 17, w(F, E) = 19
w(F, B) is smallest but forms cycle
Discard it
w(F, A) is smallest but forms cycle
Discard it
choose e = (FE)
12
A B 1
17 7
15 F 2 C
19 10
14 6
E D
The final minimum spanning tree is :
12
A B 1
F C
19 10
6
E D
Answer
i. In this algorithm, we choose an edge of G which has smallest weight
among the edges of G which are not loops.
ii. This algorithm gives an acyclic subgraph T of G and the theorem given
below proves that T is minimal spanning tree of G. Following steps are
required :
Data Structure 4–19 A (CS/IT-Sem-3)
Step 1 : Choose e1, an edge of G, such that weight of e1, w(e1) is as small
as possible and e1 is not a loop.
Step 2 : If edges e1, e2, ........., ei have been selected then choose an edge
ei+1 not already chosen such that
i. the induced subgraph, G[{e1 ..... ei+1}] is acyclic and
ii. w(ei+1) is as small as possible
Step 3 : If G has n vertices, stop after n – 1 edges have been chosen.
Otherwise repeat step 2.
If G be a weighted connected graph in which the weight of the edges are all
non-negative numbers, let T be a sub-graph of G obtained by Kruskal’s
algorithm then, T is minimal spanning tree.
Answer
a.
A B 23 F 28 G 38 ×
B A 23 C 20 G 1 ×
C B 20 D 15 G 4 ×
D C 15 E 3 G 9 ×
E D 3 F 17 G 18 ×
F A 28 E 17 G 25 ×
G A 38 B 1 C 4 D 9 E 18 F 25 ×
Fig. 4.15.2.
b.
Kruskal’s algorithm :
i. We will choose e = BG as it has minimum weight.
B C
1
A D
G
F E
4–20 A (CS/IT-Sem-3) Graphs
c 5 e
Fig. 4.16.1.
Data Structure 4–21 A (CS/IT-Sem-3)
Answer
Spanning tree : Refer Q. 4.10, Page 4–13A, Unit-4.
Kruskal’s algorithm : Refer Q. 4.14, Page 4–18A, Unit-4.
Prim’s algorithm : Refer Q. 4.11, Page 4–13A, Unit-4.
Complexity :
A. Time complexity of Prim’s algorithm :
1. The time complexity of Prim’s algorithm depends on the data
structures used for the graph and for ordering the edges by weight.
2. A simple implementation of Prim’s, using an adjacency matrix or an
adjacency list graph representation and linearly searching an array
of weights to find the minimum weight edge to add, requires O(|V|2)
running time.
B. Time complexity of Kruskal’s algorithm :
1. Kruskal’s algorithm can be shown to run in O(E log E) time, or
equivalently, O(E log V) time, where E is the number of edges in
the graph and V is the number of vertices, all with simple data
structures.
2. These running times are equivalent because :
a. E is at most V2 and log V2 = 2 log V is O(log V).
b. Each isolated vertex is a separate component of the minimum
spanning forest. If we ignore isolated vertices we obtain V
2E, so log V is O(log E).
Numerical :
Let us take ‘a’ as a source node.
Now look on weight
w(a, d) = 2, w(a, b) = 9
w(a, c) = 5
w(a, d) is smallest.
Choose e = (a, d)
9
a b
2 6
d
4 4 5
5
c 5 e
Now look on weight
w(d, b) = 6, w(d, c) = 4, w(d, e) = 4
w(d, c) is smallest.
Choose e = (d, c)
9
a b
2 6
d
4 4 5
5
c 5 e
4–22 A (CS/IT-Sem-3) Graphs
c 5 e
Now look on weight : w(e, b) = 5, w(e, d) = 4
w(e, d) is smallest but forms a cycle. So discard it.
Now w(e, b) is smallest.
Choose e = (e, b)
9
a b
2 6
d
4 4 5
5
c 5 e
Final minimum spanning tree is :
a b
2
d
4 5
c 5 e
The minimal spanning tree is adceb.
Cost of minimal spanning tree is = 2 + 4 + 5 + 5 = 16.
Que 4.17. Find the minimum spanning tree for following graph
using Prim’s and Kruskal’s algorithms.
4 C
4 B 2 1
E
A F
4
2 3
1 10
D
G 5
6
3
5 4
H J I
2 3
Fig. 4.17.1.
Data Structure 4–23 A (CS/IT-Sem-3)
Answer
Prim’s algorithm :
1. According to algorithm we choose vertex A from the set {A, B, C, D, E,
F, G, H, I, J}.
4 C
4 B 2 1
A E
4 F
2
1 10 3
D 5
G
6 3
5 4
H J
2 I
3
Fig. 4.17.2.
H J I
2 3
Fig. 4.17.3.
Now we look on weight
w(A, B) = 4, w(D, B) = 4
w(D, H) = 5, w(D, J) = 6
4
B C
4 2
1
A 4 E
2 F
1 10 3
D G
5
5 6 4 3
H J I
2 3
Fig. 4.17.4.
We choose e = AB since it is minimum.
w(D, B) can also be chosen because it has same value.
Again, w(B, C) = 4, w(B, J) = 10, w(D, H) = 5, w(D, J) = 6
4–24 A (CS/IT-Sem-3) Graphs
B 4 C
4 2 1
A 4 E F
2 3
1 10
D G
5 6 4 3 5
H J I
2 3
Fig. 4.17.5.
We choose e = BC since it has minimum value.
Now, w(B, J) = 10, w(C, E) = 2, w(C, F) = 1
We choose e = CF because w(C, F) has minimum value.
Now, w(C, E) = 2, w(F, G) = 3, w(F, I) = 5
B 4 C
4 2 1
A 4 E F
2 3
1 10
D G
6 4 3 5
5
H J I
2 3
Fig. 4.17.6.
We choose e = CE, since w(C, E) has minimum value.
w(E, G) = 2, w(F, G) = 3, w(F, I) = 5
B 4 C
4 2 1
A 4 E F
2 3
1 10
D G
5 6 4 3 5
H J I
2 3
Fig. 4.17.7.
We choose e = EG, since w(E, G) has minimum value.
w(G, J) = 4, w(G, I) = 3, w(F, I) = 5
B 4 C
4 2 1
A 4 E F
2 3
1 10
D G
5 6 4 3 5
H J I
2 3
Fig. 4.17.8.
Data Structure 4–25 A (CS/IT-Sem-3)
A 4 F
E
2
1 10 3
D G
6 3 5
5 4
H J I
2 3
Fig. 4.17.9.
We choose e = IJ, since w(I, J) has minimum value, w(J, H) = 2
Hence, e = JH will be chosen. The final minimal spanning tree is :
B 4 C
4 2 1
A E F
2
1
D G
4
3
H J I
2 3
Fig. 4.17.10.
Kruskal’s algorithm :
i. We will choose e = AD and CF as it has minimum weight.
B 4 C
4
2 1
A
4 E F
1 2
D 10 3
G
5 6
4 3 5
H
I
2 J
3
Fig. 4.17.11.
ii. Now choose e = CF.
B 4 C
4
2 1
A
4 E F
1 2
D 10 3
G
5 6
4 3 5
H
I
2 J
3
Fig. 4.17.12.
4–26 A (CS/IT-Sem-3) Graphs
iii. Choose CE, EG and HJ since they have same and minimum weights.
B 4 C
4
2 1
A
4 E F
1 2
D 10 3
G
5 6
4 3 5
H
I
2 J
3
Fig. 4.17.13.
iv. Choose IJ and GI as it has minimum weight and discard GF because
it forms cycle.
B 4 C
4
2 1
A
4 E F
1 2
D 10
G 3
5 6
4 3 5
H
I
2 J
3
Fig. 4.17.14.
v. Choose AB and BC and discard BD, GJ, DH, DJ, BJ, FI because
they form cycle.
We get the final minimal spanning tree as
B 4 C
4
A 2 1
E F
1 2
D
G
5 6 3
4
H 2 J I
3
Fig. 4.17.15.
a 3
b
8 5 6
1 9
7
4
c d
2 3
e
Fig. 4.18.1.
Answer
Prim’s algorithm : Refer Q. 4.11, Page 4–13A, Unit-4.
Kruskal’s algorithm : Refer Q. 4.14, Page 4–18A, Unit-4.
Numerical :
a 3
b
8 5 6
1 9
7
4
c d
2 3
e
Fig. 4.18.2.
Start with source node = a
Now, edge with smallest weight incident on a is e = (a, c).
So, we choose e = (a, c).
Now we look on weights :
w(c, d) = 4, w(c, e) = 2, w(c, b) = 5
a 3
b
5 6
1 9
8 7
4
c d
2 3
e
Fig. 4.18.3.
Since minimum is w(c, e) = 2. We choose e = (c, e)
Again, w(e, d) = 3
w(e, a) = 8
w(e, b) = 7
4–28 A (CS/IT-Sem-3) Graphs
a 3
b
5 6
1 9
8 7
c 4
d
2 3
e
Fig. 4.18.4.
Since minimum is w(e, d) = 3, we choose e = (e, d)
a 3
b
5 6
1 9
8 7
c 4
d
2
3
e
Fig. 4.18.5.
a 3
b
5 6
1 9
8 7
4
c d
2
3
e
Fig. 4.18.6.
a 3
b
c d
2
3
e
Fig. 4.18.7.
Data Structure 4–29 A (CS/IT-Sem-3)
Questions-Answers
Answer
1. The transitive closure of a graph G is defined to be the graph G such
that G has the same nodes as G and there is an edge (vi, vj) in G
whenever there is a path from vi to vj in G.
2. Accordingly the path matrix P of the graph G is precisely the adjacency
matrix of its transitive closure G.
3. The transitive closure of a graph G is defined as G* or G = (V, E*).
where, E* = {(i, j) the re is a path from verte x i to
vertex j in G}
4. We construct the transitive closure G* = (V, E*) by putting edge (i, j)
into E* if and only if tij(n) = 1.
( k)
5. The recursive definition of tij is
0 if i j and (i, j ) E
tij(0) =
1 if i j or (i, j) E
and for k 1
tij( k) = tij( k1) (tik
( k1) (k 1)
tkj )
Que 4.20. Write down Warshall’s algorithm for finding all pair
shortest path.
Answer
1. Floyd Warshall algorithm is a graph analysis algorithm for finding
shortest paths in a weighted, directed graph.
2. A single execution of the algorithm will find the shortest path between
all pairs of vertices.
3. It does so in (V3) time, where V is the number of vertices in the graph.
4. Negative-weight edges may be present, but we shall assume that there
are no negative-weight cycles.
4–30 A (CS/IT-Sem-3) Graphs
Que 4.21. Write the Floyd Warshall algorithm to compute the all
pair shortest path. Apply the algorithm on following graph :
8 h2
2
h1 6
3 h3
1
h6
7
2 5 3
h5
h4
8
Fig. 4.21.2.
Answer
Floyd’s Warshall algorithm : Refer Q. 4.20, Page 4–29A, Unit-4.
Numerical : We cannot solve this using Floyd Warshall algorithm because
the given graph is undirected.
Data Structure 4–31 A (CS/IT-Sem-3)
Answer
a. Dijkstra’s algorithm, is a greedy algorithm that solves the single-source
shortest path problem for a directed graph G = (V, E) with non-negative
edge weights, i.e., we assume that w(u, v) 0 each edge (u, v) E.
b. Dijkstra’s algorithm maintains a set S of vertices whose final shortest-
path weights from the source s have already been determined.
c. That is, for all vertices v S, we have d[v] = (s, v).
d. The algorithm repeatedly selects the vertex u V – S with the minimum
shortest-path estimate, inserts u into S, and relaxes all edges leaving u.
e. We maintain a priority queue Q that contains all the vertices in
v – s, keyed by their d values.
f. Graph G is represented by adjacency list.
g. Dijkstra’s always chooses the “lightest or “closest” vertex in V – S to
insert into set S, that it uses as a greedy strategy.
DIJKSTRA (G, w, s)
1. INITIALIZE-SINGLE-SOURCE (G, s)
2. S
3. Q V[G]
4. while Q
5. do u EXTRACT-MIN (Q)
6. S S {u}
7. for each vertex v Adj [u]
8. do RELAX (u, v, w)
Que 4.23. Find out the shortest path from node 1 to node 4 in a
given graph (Fig. 4.23.1) using Dijkstra shortest path algorithm.
2 10
7
14 3
1 5
3
8 12
1 4
7 12 2
5
4 20
6
6
Fig. 4.23.1.
Answer
1 2 3 4 5 6 7
0
0 7 17 8
0 7 17 8
0 7 11 14 8
0 7 11 16 12 14 8
0 7 11 14 12 14 8
0 7 11 14 12 14 8
Shortest path from node 1 to node 4 = 0 + 7 + 11 + 14 = 32
Que 4.24. Describe Dijkstra’s algorithm for finding shortest path.
Describe its working for the graph given below.
A 100
10
30 E
B 10
60
50
Wxz
C D
20
Fig. 4.24.1.
Answer
Algorithm : Refer Q. 4.22, Page 4–31A, Unit-4.
Numerical :
A 100
10
E
B 30 10
60
50
C D
20
Data Structure 4–33 A (CS/IT-Sem-3)
0
A 100
10 A B C D E
E
30 10 0
B
60
50
C D
20
0
A
100
10
E 100 A B C D E
B 30 10
10 0
60
50 10 30 100
C D 30
20
0
A
100
10
E 100 A B C D E
B 30 10
10 0
60
50 10 30 100
C D 30
20
0
A 100
10
E 100 A B C D E
B 30 10
10 0
60
50 10 30 100
C D 30 60 30 100
20
60
4–34 A (CS/IT-Sem-3) Graphs
Extract min(D) :
0
A 100
10
E 100 A B C D E
B 30 10
10 0
60
50 10 30 100
C D 30 60 30 100
20
60
0
A 100
10 90
30 E A B C D E
B 10
10 0
60 10 30 100
50
C D 30 60 30 100
20
50 50 90
Extract min(C) :
0
A
100
10
E 90 A B C D E
B 30 10
10 0
60
50 10 30 100
C D 30 60 30 100
20
50 50 90
Extract min(E) :
0
A 100
10 60 A B C D E
E
B 30 10 0
10
60 10 30 100
50
C D 30 60 30 100
50 20
50 90
60
Shortest path :
0 A
10
30 E 60
B
10 10
C D 30
20
50
2 4 2
9 12
1 4 5 3 6
4 13 15
3 5
Fig. 4.25.1.
Answer
Initialize :
2 4 2 S={}
9 12
0 1 4 6 Q: 1 2 3 4 5 6
5 3
0
4 3 5 15
13
4–36 A (CS/IT-Sem-3) Graphs
4 0
3 5 15
13 9 4 – – –
4
EXTRACT – MIN (3) :
9
12
2 4 2
9 S = { 1, 3 }
0 1 4 5 3 6 Q: 1 2 3 4 5 6
4 15 0
3 5
13 9 4 – – –
4
Relax all edges leaving 3 :
8
12 S = { 1, 3 }
2 4 2
9
Q: 1 2 3 4 5 6
0 1 4 5 3 6
0
4 3 5 15 9 4 – – –
13
4 17 8 – 17 –
EXTRACT – MIN (2) :
8
12 S = { 1, 3, 2 }
2 4 2
9
Q: 1 2 3 4 5 6
0 1 4 5 3 6
0
4 3 5 15 9 4 – – –
13
4 17 8 – 17 –
Data Structure 4–37 A (CS/IT-Sem-3)
8 16 S = { 1, 3, 2, 5, 4 }
12
2 4 2 Q: 1 2 3 4 5 6
9
0 1 6 28 0
4 5 3
9 4 – – –
4 3 5 15
13 8 – 17 –
4 13
20 13 –
16 28
4–38 A (CS/IT-Sem-3) Graphs
2 10
7
14
1 3 5
3
8 12
1 4
7 12 2
5
4 20
6
6
Fig. 1.
12
A B 1
17 7
15 F 2 C
19 10
14 6
E D
Fig. 2.
a 3
b
8 5 6
1 9
7
4
c d
2 3
e
Fig. 4.
8 h2
2
h1 6
3 h3
1
h6
7
2 5 3
h5
h4
8
Fig. 5.
60
50
C D
20
Fig. 6.
Ans. Refer Q. 4.24.
2 10
7
14 3
1 5
3
8 12
1 4
7 12 2
5
4 20
6
6
Fig. 7.
1 4 5 3 6
4 13 15
3 5
Fig. 8.
Ans. Refer Q. 4.25.
Data Structure 5–1 A (CS/IT-Sem-3)
5 Trees
CONTENTS
Part-1 : Basic Terminology Used With ................... 5–2A to 5–8A
Tree, Binary Trees, Binary
Tree Representation : Array
Representation and Pointer
(Linked List) Representation
PART-1
Basic Terminology used with Tree, Binary Trees, Binary Tree
Representation : Array Representation and Pointer (Linked List)
Representation.
Questions-Answers
Answer
i. Tree : A tree T is a finite non-empty set of elements. One of these
elements is called the root, and the remaining elements, if any is
partitioned into trees is called subtree of T. A tree is a non-linear data
structure.
ii. Vertex of tree : Each node of a tree is known as vertex of tree.
A
Vertex of tree
B C
Fig. 5.1.1.
iii. Depth : The depth of binary tree is the maximum level of any leaf in the
tree. This equals the length of the longest path from the root to any leaf.
Depth of Fig. 5.1.2 tree is 2.
A
B C
D E F
Fig. 5.1.2.
iv. Degree of an element : The number of children of node is known as
degree of the element.
Data Structure 5–3 A (CS/IT-Sem-3)
Answer
If we consider the maximum nodes in a tree then all leaves will have the
same depth and all internal nodes have left child and right child both.
Node
depth 0 20 = 1
depth 1 21 = 2
depth 2 22 = 4
depth 3 23 = 8
Fig. 5.2.1.
1. The root has 2 children at depth 1, each of which has 2 children at depth
2 i.e., 4.
2. Thus, the number of leaves at depth h is 2h, so we can calculate the
maximum number of nodes in a binary tree as :
= 1 + 2 + 4 + 8 + 16 + ... 2h
= 20 + 21 + 22 + 23 + ... 2h
h
2h 1 1
i
= 2
i 0 21
= 2h + 1 – 1
Answer
1. In an array representation, nodes of the tree are stored level-by-level,
starting from 0th level.
2. Missing elements are represented by white boxes.
3. This representation scheme is wasteful of space when many elements
are missing.
4. In fact, a binary tree that has n-elements may require an array of size
up to 2n (including position 0) for its representation.
5–4 A (CS/IT-Sem-3) Trees
5. This maximum size is needed when each element (except the root) of
the n-element binary tree is the right child of its parent.
6. Fig. 5.3.1, shows such a binary tree with four elements. Binary trees of
this type are called right-skewed binary trees.
1
2 3
4 5 6 7
A B C D E
Fig. 5.3.1.
Answer
1. Consider a binary tree T which uses three parallel arrays, INFO, LEFT
and RIGHT, and a pointer variable ROOT.
2. First of all, each node N of T will correspond to a location K such that :
a. INFO[K] contains the data at the node N.
b. LEFT[K] contains the location of the left child of node N.
c. RIGHT[K] contains the location of the right child of node N.
3. ROOT will contain the location of the root R of T.
4. If any subtree is empty, then the corresponding pointer will contain
the null value.
5. If the tree T itself is empty, then ROOT will contain the null value.
6. INFO may actually be a linear array of records or a collection of parallel
arrays.
Answer
#include<stdlib.h>
#include<stdio.h>
struct bin_tree {
int data;
struct bin_tree *right, *left;
};
typedef struct bin_tree node;
void insert(node *tree, int val)
{
node *temp = NULL;
if(!(*tree))
{
Data Structure 5–5 A (CS/IT-Sem-3)
Answer
#include<stdio.h>
#include<stdlib.h>
struct node
{
int value;
node* left;
node* right;
};
struct node* root;
struct node* insert(struct node* r, int data);
void inorder(struct node* r);
void preorder(struct node* r);
void postorder(struct node* r);
int main()
{
root = NULL;
int n, v;
printf(“How many data do you want to insert ?\n”);
scanf(“%d”, &n);
for(int i=0; i<n; i++){
printf(“Data %d: ”, i+1);
scanf(“%d”, &v);
root = insert(root, v);
Data Structure 5–7 A (CS/IT-Sem-3)
}
printf(“Inorder Traversal :”);
inorder(root);
printf(“\n”);
printf(“Preorder Traversal :”);
preorder(root);
printf(“\n”);
printf(“Postorder Traversal :”);
postorder(root);
printf(“\n”);
return 0;
}
struct node* insert(struct node* r, int data)
{
if(r==NULL)
{
r = (struct node*) malloc(sizeof(struct node));
r->value = data;
r->left = NULL;
r->right = NULL;
}
else if(data < r->value){
r->left = insert(r->left, data);
}
else {
r->right = insert(r->right, data);
}
return r;
}
void inorder(struct node* r)
{
if(r!=NULL){
inorder(r->left);
printf(“%d ”, r->value);
inorder(r->right);
}
}
void preorder(struct node* r)
{
if(r!=NULL){
printf(“%d”, r->value);
preorder(r->left);
preorder(r->right);
}
}
void postorder(struct node* r)
{
5–8 A (CS/IT-Sem-3) Trees
if(r!=NULL){
postorder(r->left);
postorder(r->right);
printf(“%d”, r->value);
}
}
Output :
How many data do you want to insert ?
5
Preorder Traversal :
32145
Inorder Traversal :
12345
Postorder Traversal :
12543
PART-2
Binary Search Tree, Strictly Binary Tree, Complete Binary Tree,
A Extended Binary Tree.
Questions-Answers
Que 5.7. Explain binary search tree and its operations. Make a
binary search tree for the following sequence of numbers, show all
steps : 45, 32, 90, 34, 68, 72, 15, 24, 30, 66, 11, 50, 10.
AKTU 2015-16, Marks 10
Answer
c. The keys, if any in the right subtree of the root are larger than the
keys in the node.
d. The left and right subtrees of the root are also binary search tree.
Various operations of BST are :
a. Searching in a BST :
Searching for a data in a binary search tree is much faster than in
arrays or linked lists. The TREE-SEARCH (x, k) algorithm searches the
tree root at x for a node whose key value equals to k. It returns a pointer
to the node if it exist otherwise NIL.
TREE-SEARCH (x, k)
1. If x = NIL or k = key [x]
2. then return x
3. If k < key [x]
4. then return TREE-SEARCH (left [x], k)
5. else return TREE-SEARCH (right [x], k)
b. Traversal operation on BST :
All the traversal operations are applicable in binary search trees. The
inorder traversal on a binary search tree gives the sorted order of data
in ascending (increasing) order.
c. Insertion of data into a binary search tree :
To insert a new value w into a binary search tree T, we use the procedure
TREE-INSERT. The procedure passed a node z for which key[z] = w,
left [z] = NIL and Right [z] = NIL.
1. y NIL
2. x root [T]
3. while x NIL
4. do y x
5. if key [z] < key [x]
6. then x left [x]
7. else x right [x]
8. P[z] y
9. if y = NIL
10. then root [T] z
11. else if key [z] < key [y]
12. then left [y] z
13. else right [y] z
d. Delete a node : Deletion of a node from a BST depends on the number
of its children. Suppose to delete a node with key = z from BST T, there
are 3 cases that can occur.
Case 1 : N has no children. Then N is deleted from T by simply replacing
the location of N in the parent node P(N) by the null pointer.
Case 2 : N has exactly one child. Then N is deleted from T by simply
replacing the location of N in P(N) by the location of the only child of N.
Case 3 : N has two children. Let S(N) denote the inorder successor of N.
(The reader can verify that S(N) does not have a left child). Then N is
deleted from T by first deleting S(N) from T (by using Case 1 or Case 2)
and then replacing node N in T by the node S(N).
5–10 A (CS/IT-Sem-3) Trees
Numerical :
1. Insert 45 : 2. Insert 32 :
45 45
32
3. Insert 90 : 4. Insert 34 :
45
45
32 90
32 90
34
5. Insert 68 : 6. Insert 72 :
45
45
32 90
32 90
34 68
34 68
72
7. Insert 15 : 8. Insert 24 :
45 45
32 90 32 90
15 34 68 15 34 68
72
24 72
9. Insert 30 : 10. Insert 66 :
45 45
32 90 32 90
15 34 68 15 34 68
24 72 24 66 72
30 30
11. Insert 11 :
45
32 90
15 34 68
11 24 66 72
30
Data Structure 5–11 A (CS/IT-Sem-3)
12. Insert 50 :
45
32 90
15 34 68
11 24 66 72
30 50
45
13. Insert 10 :
32 90
15 34 68
11 24 66 72
10 30 50
Que 5.8. Define binary search tree. Create BST for the following
data, show all steps :
20, 10, 25, 5, 15, 22, 30, 3, 14, 13 AKTU 2014-15, Marks 10
Answer
Binary search tree : Refer Q. 5.7, Page 5–8A, Unit-5.
Numerical :
20, 10, 25, 5, 15, 22, 30, 3, 14, 13
1. Insert 20 : 2. Insert 10 :
20
20
10
3. Insert 25 : 4. Insert 5 :
20 20
10 25 10 25
5
5–12 A (CS/IT-Sem-3) Trees
5. Insert 15 : 6. Insert 22 :
20 20
10 25 10 25
5 15 5 15
22
7. Insert 30 : 8. Insert 3 :
20 20
10 25 10 25
5 15 5 15 22 30
22 30
3
9. Insert 14 : 10. Insert 13 :
20
20
10 25
10 25
5 15 22 30
5 15 22 30
3 14
3 14
13
Answer
Strictly binary tree :
a. If every non-leaf node in a binary tree has non-empty left and right
subtree, the tree is termed as strictly binary tree.
b. A strictly binary tree with n leaves always contains 2n – 1 nodes.
c. If every non-leaf node in a binary tree has exactly two children, the tree
is known as strictly binary tree.
Complete binary tree : A tree is called a complete binary tree if tree
satisfies following conditions :
a. Each node has exactly two children except leaf node.
b. All leaf nodes are at same level.
c. If a binary tree contains m nodes at level l, it contains atmost 2m nodes
at level l + 1.
Extended binary tree :
a. A binary tree T is said to be 2-tree or extended binary tree if each node
has either 0 or 2 children.
b. Nodes with 2 children are called internal nodes and nodes with 0 children
are called external nodes.
Data Structure 5–13 A (CS/IT-Sem-3)
PART-3
Tree Traversal Algorithm : Inorder, Preorder and Postorder,
Constructing Binary Tree From Given Tree Traversal.
Questions-Answers
Que 5.10. Define tree, binary tree, complete binary tree and full
binary tree. Write algorithm or function to obtain traversals of a
binary tree in preorder, postorder and inorder.
AKTU 2017-18, Marks 07
Answer
Tree : Refer Q. 5.1, Page 5–2A, Unit-5.
Binary tree :
1. A binary tree T is defined as a finite set of elements called nodes, such
that :
a. T is empty (called the null tree).
b. T contains a distinguished node R, called the root of T, and the
remaining nodes of T form an ordered pair of disjoint binary trees
T1 and T2.
2. If T does contain a root R, then the two trees T1 and T2 are called,
respectively, the left and right subtrees of R.
3. If T1 is non-empty, then its root is called the left successor of R similarly,
if T2 is non-empty, then its root is called the right successor of R.
Complete binary tree : Refer Q. 5.10, Page 5–14A, Unit-5.
Full binary tree :
1. A full binary tree is formed when each missing child in the binary tree is
replaced with a node having no children.
2. These leaf nodes are drawn as squares in the Fig. 5.10.1.
1
2 3
4 5 6
Answer
Step 1 : In preorder traversal root is the first node. So, G is the root node of
the binary tree. So,
root
G
Step 2 : We can find the node of left sub-tree and right sub-tree with
inorder sequence. So,
G
Q, B, K, C, F, A P, E, D, H, R
5–16 A (CS/IT-Sem-3) Trees
Step 3 : Now, the left child of the root node will be the first node in the
preorder sequence after root node G. So,
G
B P, E, D, H, R
Q K, C, F, A
Step 4 : In inorder sequence, Q is on the left side of B and A is on the right
side B. So,
B P, E, D, H, R
Q A
K, C, F
B P, E, D, H, R
Q A
K F
B P
Q A E, D, H, R
K F
Data Structure 5–17 A (CS/IT-Sem-3)
B P
Q A D
C E R
K F H
Postorder of tree : Q, K, F, A, B, E, H, R, D, P, G
Answer
From preorder traversal, we get root node to be A.
A
DBHE IFJCG
Now considering left subtree.
Observing both the traversal we can get B as root node and D as left child and
HE as a right subtree.
B
IFJCG
D HE
Now observing the preorder traversal we get E as a root node and H as a left
child.
A
B
IFJCG
D E
H
Repeating the above process with the right subtree of root node A, we finally
obtain the required tree in given Fig. 5.12.1.
5–18 A (CS/IT-Sem-3) Trees
A
B C
D H F G
E I J
Fig. 5.12.1.
Answer
From preorder traversal, we get root node to be A.
A
EGDHFIJ
BC
Now considering left subtree.
Observing both the traversal we can get B as root node and C as right child.
A
B EGDHFIJ
C
Now, consider the right subtree.
Preorder traversal is DEGFHIJ, which shows D is root node.
Inorder traversal is EGDHFIJ, which shows EG is left subtree and HFIJ is
right subtree.
A
B D
HFIJ
C EG
Now, consider the left subtree of D.
Preorder traversal is EG and inorder traversal is EG.
E is root node and G is right subtree.
A
B D
HFIJ
C E
G
Data Structure 5–19 A (CS/IT-Sem-3)
B D
F
C E
H I
G
J
PART-4
Operation of Insertion, Deletion, Searching and Modification of
Data in Binary Search.
Questions-Answers
Answer
INSBST(INFO, LEFT, RIGHT, ROOT, AVAIL, ITEM, LOC)
A binary search tree T is in memory and an ITEM of information is given.
This algorithm finds the location LOC of ITEM in T or adds ITEM as a new
node in T at location LOC.
1. Call FIND(INFO, LEFT, RIGHT, ROOT, ITEM, LOC, PAR).
2. If LOC NULL, then Exit.
3. [Copy ITEM into new node in AVAIL list.]
a. If AVAIL = NULL, then write OVERFLOW, and Exit.
b. Set NEW := AVAIL, AVAIL := LEFT[AVAIL] and
INFO[NEW] := ITEM.
c. Set LOC := NEW, LEFT[NEW] := NULL and
RIGHT[NEW] := NULL.
4. [Add ITEM to tree.]
If PAR = NULL, then :
Set ROOT := NEW.
Else if ITEM < INFO[PAR], then:
Set LEFT[PAR] := NEW.
Else :
Set RIGHT[PAR] := NEW
[End of If structure]
5–20 A (CS/IT-Sem-3) Trees
5. Exit.
Que 5.15. Write the algorithm for deletion of an element in binary
Answer
DEL(INFO, LEFT, RIGHT, ROOT, AVAIL, ITEM)
A binary search tree T is in memory, and an ITEM of information is given.
This algorithm deletes ITEM from the tree.
1. [Find the locations of ITEM and its parent]
Call FIND(INFO, LEFT, RIGHT, ROOT, ITEM, LOC, PAR)
2. [ITEM in tree ?]
If LOC = NULL, then write ITEM not in tree, and Exit.
3. [Delete node containing ITEM]
If RIGHT[LOC] NULL and LEFT[LOC] NULL, then :
Call CASEB(INFO, LEFT, RIGHT, ROOT, LOC, PAR)
Else :
Call CASEA(INFO, LEFT, RIGHT, ROOT, LOC, PAR)
[End of If structure]
4. [Return deleted node to the AVAIL list]
Set LEFT[LOC] := AVAIL and AVAIL := LOC
5. Exit.
Answer
CASEA(INFO, LEFT, RIGHT, ROOT, LOC, PAR)
This procedure deletes the node N at location LOC, where N does not have
two children. The pointer PAR gives the location of the parent of N, or else
PAR = NULL indicates that N is the root node. The pointer CHILD gives the
location of the only child of N, or else CHILD = NULL indicates N has no
children.
1. [Initializes CHILD]
If LEFT[LOC] = NULL and RIGHT[LOC] = NULL, then:
Set CHILD := NULL.
Else if LEFT(LOC) NULL, then :
Set CHILD := LEFT[LOC].
Else
Set CHILD := RIGHT[LOC].
[End of If structure.]
2. If PAR NULL, then :
If LOC = LEFT[PAR], then :
Set LEFT[PAR] := CHILD.
Else :
Set RIGHT[PAR] := CHILD.
Data Structure 5–21 A (CS/IT-Sem-3)
[End of If structure.]
Else :
Set ROOT := CHILD.
[End of If structure.]
3. Return.
Answer
CASEB(INFO, LEFT, RIGHT, ROOT, LOC, PAR)
This procedure will delete the node N at location LOC, where N has two
children. The pointer PAR gives the location of the parent of N, or else PAR
= NULL indicates that N is the root node. The pointer SUC gives the
location of the inorder successor of N, and PARSUC gives the location of
the parent of the inorder successor.
1. [Find SUC and PARSUC]
a. Set PTR := RIGHT[LOC] and SAVE := LOC.
b. Repeat while LEFT[PTR] NULL:
Set SAVE := PTR and PTR := LEFT[PTR].
[End of loop.]
c. Set SUC := PTR and PARSUC := SAVE.
2. [Delete inorder successor]
Call CASEA(INFO, LEFT, RIGHT, ROOT, SUC, PARSUC).
3. [Replace node N by its inorder successor.]
a. If PAR NULL, then:
If LOC = LEFT[PAR], then:
Set LEFT[PAR] := SUC.
Else :
Set RIGHT[PAR] := SUC
[End of If structure.]
Else :
Set ROOT := SUC.
[End of If structure.]
b. Set LEFT[SUC] := LEFT[LOC] and
RIGHT[SUC] := RIGHT[LOC].
4. Return.
Answer
FIND(INFO, LEFT, RIGHT, ROOT, ITEM, LOC, PAR)
A binary search tree T is the memory and an ITEM of information is given.
This procedure finds the location LOC of ITEM in T and also the location
PAR of the parent of ITEM. There are three special cases :
5–22 A (CS/IT-Sem-3) Trees
i. LOC = NULL and PAR = NULL will indicate that the tree is empty.
ii. LOC NULL and PAR = NULL will indicate that ITEM is the root of T.
iii. LOC = NULL and PAR NULL will indicate that ITEM is not in T and
can be added to T as a child of the node N with location PAR.
1. [Tree empty ?]
If ROOT = NULL, then: Set LOC := NULL and PAR := NULL, and
Return.
2. [ITEM at root ?]
If ITEM = INFO[ROOT], then: Set LOC := ROOT and PAR := NULL,
and Return.
3. [Initialize pointers PTR and SAVE.]
If ITEM < INFO[ROOT], then:
Set PTR := LEFT[ROOT] and SAVE := ROOT.
Else :
Set PTR := RIGHT[ROOT] and SAVE := ROOT.
[End of If structure.]
4. Repeart steps 5 and 6 while PTR NULL:
5. [ITEM found ?]
If ITEM = INFO[PTR], then: Set LOC := PTR and PAR := SAVE, and
Return.
6. If ITEM < INFO[PTR], then:
Set SAVE := PTR and PTR := LEFT[PTR].
Else :
Set SAVE := PTR and PTR := RIGHT[PTR].
[End of If structure]
[End of step 4 loop.]
7. [Search unsuccessful.] Set LOC := NULL and PAR := SAVE.
8. Exit.
PART-5
Threaded Binary Trees, Traversing Threaded Binary Trees,
Huffman Coding using Binary Tree.
Questions-Answers
Answer
Threaded binary tree is a binary tree in which all left child pointers that are
NULL points to its inorder predecessor and all right child pointers that are
NULL points to its inorder successor.
C
B
Null F G E
Null D Null Null
Null H
B C
H Null
C
B
Null F G D E Null
H
(c) Fully threaded binary tree
Fig. 5.19.1.
Advantages of using threaded binary tree :
1. In threaded binary tree the traversal operations are very fast.
5–24 A (CS/IT-Sem-3) Trees
Answer
Algorithm for inorder traversal in threaded binary tree :
1. Initialize current as root
2. While current is not NULL
If current does not have left child
a. Print current's data
b. Go to the right, i.e., current = current->right
Else
a. Make current as right child of the rightmost node in current’s
left subtree
b. Go to this left child, i.e., current = current->left
Answer
Huffman tree is a binary tree in which each node in the tree represents a
symbol and each leaf represent a symbol of original alphabet.
Huffman algorithm :
1. Suppose, there are n weights W1, W2, ....., Wn.
2. Take two minimum weights among the n given weights. Suppose W1
and W2 are first two minimum weights then subtree will be :
W1 + W2
W1 W2
Fig. 5.21.1.
3. Now the remaining weights will be W1 + W2, W3, W4, ....., Wn.
4. Create all subtree at the last weight.
Data Structure 5–25 A (CS/IT-Sem-3)
Numerical :
24 , 55 , 13 , 67 , 88 , 36 , 17 , 61 , 24 , 76
A B C D E F G H I J
Arrange all the numbers in ascending order :
13 , 17 , 24 , 24 , 36 , 55 , 61 , 67 , 76 , 88
C G A I F B H D J E
24 , 24 , 30 , 36 , 55 , 61 , 67 , 76 , 88
A I F B H D J E
13 17
C G
30 , 36 , 48 , 55 , 61 , 67 , 76 , 88
F B H D J E
13 17 24 24
C G A I
48 , 55 , 61 , 66 , 67 , 76 , 88
B H D J E
24 24 30 36
A I F
13 17
C G
61 , 66 , 67 , 76 , 88 , 103
H D J E
30 36 48 55
F B
13 17 24 24
C G A I
67 , 76 , 88 , 103 , 127
D J E
48 55 61 66
B H
24 24 30 36
A I F
13 17
C G
5–26 A (CS/IT-Sem-3) Trees
24 24 30 36
A I F
13 17
C G
461
191 270
Answer
Huffman algorithm : Refer Q. 5.21, Page 5–24A, Unit-5.
Numerical :
M A H R S T
, , , , ,
1 4 2 2 1 1
Arrange all the number in ascending order.
M S T H R A
, , , , ,
1 1 1 2 2 4
T H R A
, 2 , , ,
1 2 2 4
M S
1 1
H R A
, , 3 ,
2 2 4
T 2
1
M S
1 1
3 , 4 , A
4
T 2
H R
1 2 2
M S
1 1
5–28 A (CS/IT-Sem-3) Trees
A 7 11
, 0 1
4 A 7
3 4
4 0 1
T 2 H R 3 4
0 1 0 1
1 2 2 T 2 H R
M S 2 2
1 0 1
1 1
M S
1 1
Character Code
M 1010
A 0
H 110
R 111
S 1011
T 100
PART-6
Concept and Basic Operation for AVL Tree, B tree and Binary
Heaps.
Questions-Answers
Que 5.23. Define AVL trees. Explain its rotation operations with
example. Construct an AVL tree with the values 10 to 1 numbers
into an initially empty tree. AKTU 2016-17, Marks 15
Data Structure 5–29 A (CS/IT-Sem-3)
Answer
i. An AVL (or height balanced) tree is a balanced binary search tree.
ii. In an AVL tree, balance factor of every node is either –1, 0 or +1.
iii. Balance factor of a node is the difference between the heights of left and
right subtrees of that node.
Balance factor = height of left subtree – height of right subtree
iv. In order to balance a tree, there are four cases of rotations :
1. Left Left rotation (LL rotation) : In LL rotation every node moves
one position to left from the current position.
Insert 1, 2 and 3
–2 –2
1 1 0
–1 –1 2
2 2 0 0
0 0 1 3
3 3
Insert 3, 1 and 2
2 2 After LL rotation
2 After RR rotation
3 3 3 0
–1 –1 1 2
1 3 1 2 0 0
0 0 0 1 3
2 2 1
Tree is unbalanced
LL rotation RR rotation After LR rotation
because node 3 has tree is balanced
balanced factor 2
Fig. 5.23.3.
4. Right Left rotation (RL rotation) : The RL rotation is the combination
of single right rotation followed by single left rotation. In RL rotation,
first every node moves one position to right then one position to left
from the current position.
Insert 1, 3 and 2
–2 After RR –2 After LL
1 1 rotation 1 0
1 –1 rotation 2
3 3 2 0 0 0
0 0 1 3
2 2 3
Tree is unbalanced RR rotation LL rotation After RL rotation
because node 1 has tree is balanced
balance factor –2
Fig. 5.23.4.
Numerical :
Insert 10 :
0
10
Insert 9 :
1
10
0
9
Insert 8 :
2 1
10 9
1 LL 0 0
9 rotation 8 10
0
8
Insert 7 :
1
9
1 0
8 10
0
7
Data Structure 5–31 A (CS/IT-Sem-3)
Insert 6 :
2 1
9 9
2 0 LL 0 0
8 10 rotation 7 10
1 0 0
7 6 8
0
6
Insert 5 :
2 0
9 7
1 0 LL 1 0
7 10
1 0 rotation 6 9
0 0 0
6 8
5 8 10
0
5
Insert 4 :
0
1
7
7
2 0 0 0
6 9 5 9
1 0 0 LL 0 0 0 0
5 8 10 4 6 8 10
rotation
0
4
Insert 3 :
1
7
1 0
5 9
1 0 0 0
4 6 8 10
0
3
Insert 2 :
2 1
7 7
LL
2 0 1 0
5 9 rotation 5 9
2 0 0 0 0 0 0
4 6 8 10 3 6 8 10
1 0 0
3 2 4
0
2
5–32 A (CS/IT-Sem-3) Trees
Insert 1 :
2
1
7
7
2 0
0 0
5 9 LL
1 0 0 0 3 9 0
1 0 0
3 6 8 10 rotation 10
1 2 5 8
0 0 0
2 4
1 4 6
0
1
Que 5.24. Consider the following AVL tree and insert 2, 12, 7 and 10
as new node. Show proper rotation to maintain the tree as AVL.
6 10
9 11
4 7
3 5
Fig. 5.24.1.
Answer
Given tree :
–1
8
–1 0
6 10
0 9 11
4 7
3 5
Balanced tree
Data Structure 5–33 A (CS/IT-Sem-3)
–2
Insert 2 :
8
+2
0
6
10
1
4
7 9 11
1
3 5
2
Tree is unbalanced, now LL rotation is required to balance it.
+1
8
0 0
4 10
1 0 0 0
3 6 9 11
0 0
0 5 7
2
Now the tree is balanced.
Insert 12 :
0
8
0 –1
4 10
0
1 0 –1
6 11
3 9
0 0 0
0 5 7 12
2
Tree is balanced, so there is no need to balance the tree.
Insert 7 : 7 is already in the tree hence it cannot be inserted in the AVL tree.
Insert 10 : 10 is also in the tree hence it cannot be inserted in the AVL tree.
Que 5.25. What is height balanced tree ? Why height balancing of
tree is required ? Create an AVL tree for the following elements : a,
z, b, y, c, x, d, w, e, v, f. AKTU 2018-19, Marks 07
5–34 A (CS/IT-Sem-3) Trees
Answer
Height balanced tree : Refer Q. 5.23, Page 5–28A, Unit-5.
Height balancing of tree is required : Height balancing of tree is
required to implement an AVL tree. Each node must contain a balance
factor, which indicates its states of balance relative to its sub-tree.
Numerical :
Insert a :
0
a
Insert z :
–1
a
0
z
Insert b :
0
–2
a b
RL rotation 0 0
z 1 a z
0 b
Insert y :
–1
b
0 1
a z
y 0
Insert c :
–1
–2
b
b
RR rotation 0 0
0 2 a y
a z
0
c 0 z
y 1
0
c
Insert x :
–2
c 0
b
RL rotation 1 0
0 1 b y
a y
–1 0 0
a x 0 z
c z
0
x
Data Structure 5–35 A (CS/IT-Sem-3)
Insert d :
–1
c
1 1
b y
0 0
a x 1 z
d 0
Insert w :
–2
c
c –1
1 2 1 1
b y LR rotation
b d
0 0
a 0
x 2 z
a x 0 0 z
0
0
d –1 w y
0
w
Insert e :
c –1
0 0
b d
0 0
–1
a x z
0
0 0
w y e
Insert v :
–2
0
c x
1 1 0 –1
b y RL rotation
c w
0 1 –1 1
a 1
x 1 z d v 0 y
b
1 0 0 0
w y c 0 z
a 0 e
0
v
5–36 A (CS/IT-Sem-3) Trees
Insert f :
1
x
–1 –1
c w
–1 –1
1
d v 0 y
b 0
0
a e –1 z
0
f
No, rebalancing required. So, this is final AVL search tree.
Answer
Step 1 : Insert 19, 16, 21, 11, 17, 25, 6, 13 :
Insert 19 :
19
Insert 16 :
1
19
0
16
1
Insert 21 :
0
19
0 0
16 21
Insert 11 :
19
1 0
16 21
0
11
Data Structure 5–37 A (CS/IT-Sem-3)
Insert 17 :
1
19
0 0
16 21
0 0
11 17
Insert 25 :
0
19
0 –1
16 21
0 0 0
11 17 25
Insert 6 :
1
19
1 –1
16 21
1 0 0
11 17 25
0
6
Insert 13 :
1
19
1 –1
16 21
0 0 0
11 17 25
0 0
6 13
5–38 A (CS/IT-Sem-3) Trees
Step 2 : Insert 3 :
2 +1
19 19
2 –1 0 –1
16 21 LL Rotation 11 21
1 0 0 1 0 0
11 17 25 6 16 25
1 0 0 0 0
6 13 3 13 17
0
3
Step 3 : Delete 16 :
+1
19
0 –1
11 21
+1 –1 0
6 13 25
0 0
3 17
Que 5.27. Describe all rotations in AVL tree. Construct AVL tree
from the following nodes : B, C, G, E, F, D, A.
AKTU 2015-16, Marks 10
Answer
AVL rotations : Refer Q. 5.23, Page 5–28A, Unit-5.
Construction of AVL tree : B, C, G, E, F, D, A
0
Insert B : B
Insert C :
–1
B
0
C
Insert G :
–2
B 0
–1 C
C RR 0 0
0 B G
G rotation
Data Structure 5–39 A (CS/IT-Sem-3)
Insert E :
–1
C
0 1
B G
0
E
Insert F :
–2 –1
C C C
0 2 LR RR 0 0
B G B G B F
rotation rotation 0 0
–1
E F E G
0
F E
Insert D :
–2 0
C E
0 1 LR 0 –1
B F C F
1 0 rotation 0 0 0
0 E G B D G
D
Insert A :
1
E
1
–1
C F
+1
0 0
B D G
0
A
Answer
B-tree :
1. A B-tree is a self-balancing tree data structure that keeps data sorted
and allows searches, sequential access, insertions, and deletions in
logarithmic time.
2. A B-tree of order m is a tree which satisfies the following properties :
a. Every node has at most m children.
b. Every non-leaf node (except root) has at least m/2 children.
c. The root has at least two children if it is not a leaf node.
5–40 A (CS/IT-Sem-3) Trees
A U Z
Insert W :
I
A U W Z
I
Insert L :
A L U W Z
I U
A L W Z
Insert P :
I U
A L P W Z
Insert X :
I U
A L P W X Z
Insert C :
I U
A C L P W X Z
Insert J :
I U
A C J L P W X Z
Data Structure 5–41 A (CS/IT-Sem-3)
Insert D :
I U
A C D J L P W X Z
Insert M :
I U
A C D J L M P W X Z
I L U
A C D J M P W X Z
Insert T :
I L U
A C D J M P T W X Z
Insert B :
I L U
A B C D J M P T W X Z
B I L U
A C D J M P T W X Z
B L U
A C D J M P T W X Z
Insert Q :
I
B L U
A C D J M P T W X Z
B L U
A C D J M P Q T W X Z
5–42 A (CS/IT-Sem-3) Trees
Insert E :
I
B L U
A C D J M P Q T W X Z
Insert H :
I
B L P U
A C D J M Q T W X Z
I
B L P U
A C D E J M Q T W X Z
Insert S :
B L P U
A C D E H J M Q T W X Z
Insert K :
B D L P U
A C E H J M Q T W X Z
Insert N, R :
B D L P U
A C E H J M Q S T W X Z
Data Structure 5–43 A (CS/IT-Sem-3)
B D L P U
A C E H J M Q S T W X Z
I P
B D L R U
A C E H J K M N Q S T W X Z
Insert G, Y :
I P
B D L R U
A C E G H J K M N Q S T W X Y Z
I P
B D L R U X
A C E G H J K M N Q S T W Y Z
Insert F, O & V :
I P
B D L R U X
A C E F G H J K M N O Q S T V W Y Z
I P
B D F L R U X
A C E G H J K M N O Q S T V W Y Z
Answer
Insert 3 : 3
Insert 14 : 3 14
Insert 7 : 3 7 14
Insert 1 : 1 3 7 14
Insert 8 :
1 3 7 14
Insert 5 :
1 3 5 7 14
Insert 11 :
1 3 5 7 11 14
Insert 17 :
8
1 3 5 7 11 14 17
Insert 13 :
8
1 3 5 7 11 13 14 17
Insert 6 :
6 8
1 3 5 7 11 13 14 17
Insert 23 :
6 8 14
1 3 5 7 11 13 17 23
Data Structure 5–45 A (CS/IT-Sem-3)
Insert 12 :
6 8 14
1 3 5 7 11 12 13 17 23
Insert 20 :
6 8 14
1 3 5 7 11 12 13 17 20 23
Insert 26 :
6 8 14
1 3 5 7 11 12 13 17 20 23 26
Insert 4 :
6 8 14
1 3 4 5 7 11 12 13 17 20 23 26
Insert 16 :
6 8 14 20
1 3 4 5 7 11 12 13 16 17 23 26
Insert 18, 24, 25 :
6 8 14 20
1 3 4 5 7 11 12 13 16 17 18 23 24 25 26
Insert 19 :
6 8 14 20
1 3 4 5 7 11 12 13 16 17 18 19 23 24 25 26
Delete 6 :
5 8 14 20
1 3 4 7 11 12 13 16 17 18 19 23 24 25 26
5–46 A (CS/IT-Sem-3) Trees
Delete 23 :
5 8 14 20
1 3 4 7 11 12 13 16 17 18 19 24 25 26
Delete 3 :
5 8 14 20
1 4 7 11 12 13 16 17 18 19 24 25 26
Answer
10, 20, 30, 40, 50, 60, 70, 80, 90
Order of the B-tree is 3.
1. Insert 10 :
10
2. Insert 20 :
10 20
3. Insert 30 :
20
10 30
4. Insert 40 :
20
10 30 40
Data Structure 5–47 A (CS/IT-Sem-3)
5. Insert 50 : 6. Insert 60 :
20 20
10 40 10 40
30 50 30 50 60
7. Insert 70 : 8. Insert 80 :
20 20
10 40 10 40
30 60 30 60
50 70 50 70 80
9. Insert 90 :
20
10 40
30 60
50 80
70 90
This is final B-tree of order 3.
Answer
4. Data The leaf nodes of the tree The leaf nodes of the tree
store the actual record store pointers to records
rather than pointers to rather than actual records.
records.
6. Function of leaf In B+ tree, leaf node data In B-tree, the leaf node
nodes ar e or dere d in a cannot store using linked
sequential linked list. list.
7. Searching In B+ tree, searching of any In B-tree, searchi ng
data is very easy because becomes difficult as data
all data is found in leaf cannot be found in the leaf
nodes. node.
8. Search In B+ tree, the searching In B-tree, the search is not
accessibility becomes easy. that easy as compared to
a B+ tree.
Example :
B+ tree : B-tree :
3 5 3 5
1 2 6 4 8 9 1 2 6 4 8 9
Data Structure 5–49 A (CS/IT-Sem-3)
Answer
1. The binary heap data structure is an array that can be viewed as a
complete binary tree.
2. Each node of the binary tree corresponds to an element of the array.
3. The array is completely filled on all levels except possibly lowest.
4. We represent heaps in level order, going from left to right.
5. If an array A contains key values of nodes in a heap, length [A] is the
total number of elements.
Heap-size [A] = Length [A] = Number of elements.
6. The root of the tree A[1] and given index i of a node the indices of its
parent, left child and right child can be computed :
PARENT (i)
return floor (i/2)
LEFT(i)
return 2i
RIGHT (i)
return 2i + 1
Q. 5. Define tree, binary tree, complete binary tree and full binary
tree. Write algorithm or function to obtain traversals of a
binary tree in preorder, postorder and inorder.
Ans. Refer Q. 5.10.
Q. 13. Consider the following AVL tree and insert 2, 12, 7 and 10 as
new node. Show proper rotation to maintain the tree as
AVL.
Data Structure 5–51 A (CS/IT-Sem-3)
6 10
9 11
4 7
3 5
Fig. 5.24.1.
Ans. Refer Q. 5.24.
Q. 14. Construct a height balanced binary search tree by
performing following operations :
Step 1 : Insert
19, 16, 21, 11, 17, 25, 6, 13
Step 2 : Insert
3
Step 3 : Delete
16
Ans. Refer Q. 5.26.
Q. 15. What is height balanced tree ? Why height balancing of tree
is required ? Create an AVL tree for the following elements :
a, z, b, y, c, x, d, w, e, v, f.
Ans. Refer Q. 5.25.
Q. 16. Describe all rotations in AVL tree. Construct AVL tree from
the following nodes : B, C, G, E, F, D, A.
Ans. Refer Q. 5.27.
Q. 17. Define a B-tree. What are the applications of B-tree ? Draw
a B-tree of order 4 by insertion of the following keys in
order : Z, U, A, I, W, L, P, X, C, J, D, M, T, B, Q, E, H, S, K, N, R,
G, Y, F, O, V.
Ans. Refer Q. 5.28.
Q. 18. Construct a B-tree of order 5 created by inserting the
following elements 3, 14, 7, 1, 8, 5, 11, 17, 13, 6, 23, 12, 20, 26, 4,
16, 18, 24, 25, 19. Also delete elements 6, 23 and 3 from the
constructed tree.
Ans. Refer Q. 5.29.
Q. 19. Construct a B-tree on following sequence of inputs.
10, 20, 30, 40, 50, 60, 70, 80, 90
Assume that the order of the B-tree is 3.
Ans. Refer Q. 5.30.
Data Structure SQ–1 A (CS/IT-Sem-3)
SQ–6 A (CS/IT-Sem-3) 2 Marks Questions
SQ–10 A (CS/IT-Sem-3) 2 Marks Questions
3.12. Give the worst case and best case time complexity of binary
search. AKTU 2016-17, Marks 02
Ans. Worst case : In each comparison, the size of the search area is
reduced by half. So, the efficiency of the binary search method at
the worst case is log2 n + 1, i.e., O(log2 n + 1) where n is the total
number of items that will be used for the binary search.
Best case : The best case of binary search occurs when the element
we are searching for is the middle element of the list/array because
in that case we will get the desired result in a single go. In this case,
the time complexity of the algorithm will be O(1).
SQ–12 A (CS/IT-Sem-3) 2 Marks Questions
4 Graphs
(2 Marks Questions)
4.1. What are the applications of graphs ?
Ans. Applications of graph are :
i. Representing relationship between components in electronic
circuits.
ii. Transportation network in highway network, flight network.
iii. Computer network in local area network.
4.2. Write down the applications of DFS.
Ans. Applications of DFS :
i. Topological sorting.
ii. Finding connected components.
iii. Finding strongly connected components.
iv. Solving puzzles such as mazes.
4.3. Write down the applications of BFS.
Ans. Applications of BFS :
i. Finding all nodes within one connected component.
ii. Finding the shortest path between two nodes.
4.4. Define connected and strongly connected graph.
AKTU 2015-16, Marks 02
Ans. Connected graph : A graph G is said to be connected if there is at
least one path between every pair of vertices in G.
Strongly connected graph : A graph G is said to be strongly
connected if there is at least one directed path from every vertex to
every other vertex.
4.5. What are the advantages of DFS over BFS ?
Ans. Advantages of DFS over BFS :
i. DFS has much lower memory requirement than BFS.
ii. DFS is better than BFS if the solution is at maximum depth.
4.6. How the graph can be represented in memory ? Explain
with suitable example. AKTU 2018-19, Marks 02
OR
List the different types of representation of graphs.
AKTU 2017-18, Marks 02
Data Structure SQ–13 A (CS/IT-Sem-3)
v2 v3
Fig. 1.
Matrix representation :
v1 v2 v3 v4
v1 0 0 0 1
v2 1 0 1 0
v3 0 0 0 1
v4 0 1 0 0
Linked representation :
v1 v4 /
v2 v1 v3 /
v3 v4 /
v4 v2 /
Fig. 2.
4.7. Discuss the disadvantages of Dijkstra’s algorithm.
Ans. Disadvantages of Dijkstra’s algorithm are :
i. It does a blind search thereby consuming a lot of time and wasting
necessarily resource.
ii. It cannot handle negative edges. This leads to acyclic graphs.
4.8. How many ways are there to implement Krus kal’s
algorithm ?
Ans. Ways to implement Kruskal’s algorithm :
i. By using disjoint sets : Using UNION and FIND operation.
ii. By using priority queue : Maintains weights in priority queue.
4.9. How Prim’s algorithm is similar to Dijkstra’s algorithm ?
Ans.
i. Similar to Dijkstra algorithm, in Prim’s algorithm we also keep
distance values and paths in distance table.
ii. The implementation of Prim’s algorithm is identical to that of
Dijkstra’s algorithm so the running time is O(|V|2) without heaps
and O(E log V) using binary heaps.
SQ–14 A (CS/IT-Sem-3) 2 Marks Questions
even.
Since, deg(v) is odd for all v V2. So, the number of odd degree
vertices in a connected graph must be even.
4.11. Number of nodes in a complete tree is 100000. Find its depth.
AKTU 2018-19, Marks 02
Ans. Number of nodes in a complete tree = 100000
We know that, n= 2h + 1 – 1
(n + 1) = 2h + 1
log2(n + 1) = h+1
log2(n + 1) – 1 = h
Putting n= 100000
h= log2(100000 + 1) – 1
h= 15 (approx)
Data Structure SQ–15 A (CS/IT-Sem-3)
5 Trees
(2 Marks Questions)
5.1. Define tree.
Ans. A tree T is a finite non-empty set of elements. One of these elements
is called the root, and the remaining elements, if any is partitioned
into trees is called subtree of T. A tree is a non-linear data structure.
5.2. Define the depth of a node.
Ans. The depth of a node is the length of the path from the root to the
node. A (rooted) tree with only one node (the root) has a depth of
zero.
5.3. Describe the properties of binary tree.
Ans. Properties of binary tree are :
i. The number of nodes n in a full binary tree is 2n+1 – 1.
ii. The number of leaf nodes in a full binary tree is 2h where h is the
height.
iii. The number of NULL links in a complete binary tree of n nodes is
n + 1.
5.4. Define complete binary tree. Give example.
AKTU 2016-17, Marks 02
Ans. A tree is called complete binary tree if tree satisfies following
conditions :
1. Each node has exactly two children except leaf node.
2. All leaf nodes are at same level.
3. If a binary tree contains m nodes at level l, it contains at most 2m
nodes at level l + 1.
Example :
A
B C
D E F G
H I J K L M N O
Fig. 1.
5.5. For tree construction which is the suitable and efficient
data structure and why ? AKTU 2015-16, Marks 02
SQ–16 A (CS/IT-Sem-3) 2 Marks Questions
Ans. Linked list is the most suitable and efficient data structure because
it is easily accessible due to the concept of pointer used in it.
5.6. Discuss the concept of “successor” and “predecessor” in
binary search tree. AKTU 2017-18, Marks 02
Ans. In binary search tree, if a node X has two children, then its
predecessor is the maximum value in its left subtree and its successor
is the minimum value in its right subtree.
5.7. Explain height balanced tree. List general cases to maintain
the height. AKTU 2017-18, Marks 02
Ans.
i. An AVL (or height balanced) tree is a balanced binary search tree.
ii. In an AVL tree, balance factor of every node is either –1, 0 or +1.
iii. Balance factor of a node is the difference between the heights of
left and right subtrees of that node.
Balance factor = height of left subtree – height of right subtree.
General cases to maintain the height are :
a. Left Left rotation (LL rotation)
b. Right Right rotation (RR rotation)
c. Left Right rotation (LR rotation) d. Right Left rotation (RL rotation)
* *
A B + /
C D P Q
Fig. 2.
5.9. What is the maximum height of any AVL tree with 7 nodes ?
AKTU 2015-16, Marks 02
Ans. Maximum height of any AVL tree with 7 nodes is 3.
5.10. When does a graph become tree ?
AKTU 2016-17, Marks 02
Ans. A graph becomes a tree when there is exactly one path between
every pair of its vertices.
5.11. How can we traverse a binary tree ?
Ans. We can traverse a binary tree using :
1. Inorder traversing 2. Preorder traversing 3. Postorder traversing