Bca3 Data Structure
Bca3 Data Structure
By Soumi Dutta
Data Structure
Data structure is a particular way of storing and organizing data in a computer so that it can be used efficiently.
ADT: An abstract data type is a mathematical model for a certain class of data
structures that have similar behavior; or for certain data types of one or
more programming languages that have similar semantics. An abstract data type is defined indirectly, only by the operations that may be performed on
By Soumi Dutta
Data Structure
Linear Data Structure: Linear data structure is linear if element is adjacent to each other. It has exactly two neighbors elements to which it is connected as its previous and next member. Example of Linear Data Structure Array, Stack , Queue, Linked List
Non- Linear Data Structure Non-Linear data structure is that if one element can be connected to more than two adjacent element then it is known as non-linear data structure. Example of Linear Data Structure: Tree , Graph
By Soumi Dutta
Stack (LIFO): Stack follows the rule of last in first out rule. Mainly two action are performed by stack one is push and other is pop. The last thing which we
placed or push on stack is the first thing we can get when we pop. A stack is a
list of element with insertion and deletion at one end only.
By Soumi Dutta
Queue (FIFO)
Front 4 4 4 4
3
2 1 Rear 0 Rear
12
3
2 1 0 Rear
25
12
3
2 1 0 Rear
36
3
2 1 0
25
12
4 Front
36 25
4 3 2 1
3
2 1 0 Rear Front
25 12
3
2 1 0
Rear
12
Rear
12
Front
By Soumi Dutta
Linked List A linked list is a data structure which consists of data record in a sequence such that each data record have a field of data as well as link reference to its connected node. It do not provide the random access to any of its member data as it is form of a indexing and the connected node is predefined.
By Soumi Dutta
Singly link list: In the singly link list each node have two fields one for data and other is for link reference of the next node. The node have null only to the last node of the link field. This can be seen in the following picture.
Doubly link list: In the doubly link list each node have three field two fields for link which is the reference to next and previous and one for data record. The node have null only to the first node of previous and last node at the next. This can be seen in the following picture.
By Soumi Dutta
Circular link list: If talking about singly circular link list each node have two fields one for data record and other for link reference to the next node.
The last node has link reference to the first node. There in no null present
in the link of any node.
By Soumi Dutta
Tree Structure: A tree data structure that are based on hierarchical tree structure with
By Soumi Dutta
Graph Structure: A graph is a collection of nodes and edges without hierarchy and parent
child relationship.
By Soumi Dutta
Algorithm
 
A list of step by approaches to solve any problem. Two measure factors of efficiency of an algorithm :
o Space o Time
Space complexity:
Analysis of space complexity of an algorithm or program is the amount of memory it needs to run to completion.
Time complexity:
The time complexity of an algorithm or a program is the amount of time it needs to run to completion.
By Soumi Dutta
Analyze an algorithm
When we analyze an algorithm it depends on the input data, there are three cases :
Best case: In the best case, the amount of time a program might be
Asymptotic Notation
BIG OH NOTATION:
Big
The
factors in the analysis of the algorithm. Clearly, the complexity function f(n) of an algorithm increases as n increases.
By Soumi Dutta
By Soumi Dutta
STACK
By Soumi Dutta
Stack
A stack is one of the most important and useful non-primitive linear data structure. It is
an ordered collection of items into which new data items may be added/inserted and from which items may be deleted at only one end, called the top of the stack. As all the addition and deletion in a stack is done from the top of the stack, the last added element will be first removed from the stack. That is why the stack is also called Last-inFirst-out (LIFO).
PUSH: The process of adding (or inserting) a new element to the top of the stack is called
PUSH operation. Pushing an element to a stack will add the new element at the top.
After every push operation the top is incremented by one. If the array is full and no new element can be accommodated, then the stack overflow condition occurs.
POP: The process of deleting (or removing) an element from the top of stack is called POP operation. After every pop operation the stack is decremented by one. If there is no element in the stack and the pop operation is performed then the stack underflow
condition occurs.
By Soumi Dutta
By Soumi Dutta
By Soumi Dutta
By Soumi Dutta
Application Of Stack
There are a number of applications of stacks; three of them are discussed briefly in the preceding sections. Stack is internally used by compiler when we implement (or execute) any recursive function. If we want to implement a recursive function nonrecursively, stack is programmed explicitly. Stack is also used to evaluate a mathematical expression and to check the parentheses in an expression.
By Soumi Dutta
Recursion
Recursion occurs when a function is called by itself repeatedly; the function is called recursive function. The general algorithm model for any recursive function contains the following steps: 1. Prologue: Save the parameters, local variables, and return address.
2. Body: If the base criterion has been reached, then perform the final computation and go to step 3; otherwise, perform the partial computation and go to step 1 (initiate a recursive call).
3. Epilogue: Restore the most recently saved parameters, local variables, and return address.
By Soumi Dutta
RECURSION vs ITERATION
Recursion of course is an elegant programming technique, but not the best way to
solve a problem, even if it is recursive in nature. This is due to the following reasons:
& maintain,
particularly in case of data structures which are by nature recursive. Such data structures are queues, trees, and linked lists.
By Soumi Dutta
TOWER OF HANOI
The initial setup of the problem is shown below. Here three pegs (or towers) X,
Y and Z exists. There will be four different sized disks, say A, B, C and D. Each disk has a hole in the center so that it can be stacked on any of the pegs. At the
beginning, the disks are stacked on the X peg, that is the largest sized disk on
the bottom and the smallest sized disk on top. Here we have to transfer all the disks from source peg X to the destination peg Z by using an intermediate peg Y. Following are the rules to be followed during transfer : **1. Transferring the disks from the source peg to the destination peg such that at any point of transformation no large size disk is placed on the smaller one. **2. Only one disk may be moved at a time. **3. Each disk must be stacked on any one of the pegs.
By Soumi Dutta
TOWER OF HANOI
By Soumi Dutta
TOWER OF HANOI
By Soumi Dutta
TOWER OF HANOI
By Soumi Dutta
TOWER OF HANOI
By Soumi Dutta
TOWER OF HANOI
By Soumi Dutta
TOWER OF HANOI
By Soumi Dutta
EXPRESSION
Another application of stack is calculation of postfix expression. There are
basically three types of notation for an expression (mathematical expression; An expression is defined as the number of operands or data items combined
3. Postfix notation : In the postfix notation the operator(s) are written after the
operands, so it is called the postfix notation (post means after), it is also known as suffix notation or reverse polish notation.
Example: A B+
By Soumi Dutta
EXPRESSION
Thus expression A + B * C can be interpreted as A + (B * C). Using this
alternative method we can convey to the computer that multiplication has higher precedence over addition.
Operator precedence
Give postfix form for A + [ (B + C) + (D + E) * F ] / G A + { [ (BC +) + (DE +) * F ] / G} A + { [ (BC +) + (DE + F *] / G} A + { [ (BC + (DE + F * +] / G} . A + [ BC + DE + F *+ G / ]
ABC + DE + F * + G / +
By Soumi Dutta
EXPRESSION
Problem 3.4.2.2. Give postfix form for (A + B) * C / D + E ^ A / B [(AB + ) * C / D ] + [ (EA ^) / B ]
[(AB + ) * C / D ] + [ (EA ^) B / ]
[(AB + ) C * D / ] + [ (EA ^) B / ] AB + ) C * D / (EA ^) B / + AB + C * D / EA ^ B / +
By Soumi Dutta
7. Exit.
By Soumi Dutta
By Soumi Dutta
QUEUE
By Soumi Dutta
Queue
A queue is logically a first in first out (FIFO or first come first serve) linear data structure. The concept of queue can be understood by our real life problems. For example a customer come and join in a queue to take the train ticket at the end (rear) and the ticket is issued from the front end
of queue. That is, the customer who arrived first will receive the ticket first. It means the
customers are serviced in the order in which they arrive at the service centre. It is a homogeneous collection of elements in which new elements are added at one end called rear, and the existing elements are deleted from other end called front. The basic operations that can be performed on queue are 1. Insert (or add) an element to the queue (push) 2. Delete (or remove) an element from a queue (pop)  Push operation will insert (or add) an element to queue, at the rear end, by incrementing the array index.  Pop operation will delete (or remove) from the front end by decrementing the array index and will assign the deleted value to a variable.  Total number of elements present in the queue is front-rear+1, when implemented using arrays.
By Soumi Dutta
Queue Insertion
Rear Front
0 1 2 3 4
Empty Queue
-1 -1
Front
11
-1 Rear
Item=11
0 Front
0 1 2 3 4
11
-1
22
Rear
Item=22
1
By Soumi Dutta
Queue Insertion
Front
0 1 2 3 4
11
-1
22
33
Rear
Item=33
2 Front
0 1 2 3 4
11
-1
22
33
44
Rear
Item=44
3 Front
0 1 2 3 4
11
-1
22
33
44
55
Rear
Item=55
4
By Soumi Dutta
Queue Deletion
0 1 2 3 4
11
Front
22
33
44
55
Rear
Item=11
0
0 1 2 3
4
4
11
22
Front
33
44
55
Rear
Item=22
1
0 1 2 3
4
4
11
22
33
Front
44
55
Rear
Item=33
2
By Soumi Dutta
Queue Deletion
0 1 2 3 4
11
22
33
44
Front
55
Rear
Item=44
3
0 1 2 3
4
4
11
22
33
44
55
Front Rear
Item=55
By Soumi Dutta
INSERTING AN ELEMENT INTO THE QUEUE 1. Set Initialize front:=-1 rear:= 1 2. If rear >= SIZE-1 then (a) Display Queue overflow
(b) Exit
3. Else (a) Input the value to be inserted and assign to variable data (b) Rear = rear +1 (c) Q[rear] = data 6. Exit
By Soumi Dutta
By Soumi Dutta
CIRCULAR QUEUE
In circular queues the elements Q[0],Q[1],Q[2] .... Q[n  1] is represented in a circular fashion with Q[1] following Q[n]. 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. Q[0]
Q[4]
11
22
33
44
55
Q[3]
Q[1]
Q[2]
By Soumi Dutta
Empty Queue
-1 -1
11
Front Rear
Item=11
0
0
0
1 2 3 4
11
Front
22
Rear
Item=22
1
By Soumi Dutta
11
Front
22
33
Rear
Item=33
0
0 1
2
2 3 4
11
Front
22
33
44
Rear
Item=44
11
Front
22
33
44
55
Rear
Item=55
Overflow
By Soumi Dutta
Queue Deletion
0 1 2 3 4
11
22
Front
33
44
55
Rear
Item=11
1
0 1 2 3
4
4
11
22
33
Front
44
55
Rear
Item=22
2
0 1 2 3
4
4
11
22
33
44
Front
55
Rear
Item=33
3
By Soumi Dutta
Queue Deletion
0 1 2 3 4
11
22
33
44
55
Front Rear
Item=44
3
0 1 2 3 4
Rear Front
11
22
33
44
55
Item=55
-1
-1
Underflow Condition :
1. Front==-1
By Soumi Dutta
Overflow
1. front == 0 and rear == size-1
Rear
Front
Q[4]
Q[0] 55 11
2. front==rear+1 Q[3]
Rear
44
22
Q[1]
33
Q[4] Q[0] 15 55 11 11
Front
Q[2] Case: 1
Q[3]
14 44 13 33 Q[2]
12 22 Q[1]
Case: 2
By Soumi Dutta
Implementation
void Insert_queue() { if ((front == 0 && rear == size-1) || (front==rear+1)) { printf("\n Overflow"); return; } if(front==-1) { front=0;rear=0; printf("\n Input the element :"); scanf("%d", &ch); q[rear] = ch ; } else { if (rear == size-1) rear = 0; else rear ++; printf("\n Input the element :"); scanf("%d", &ch); q[rear] = ch ; } } By Soumi Dutta
Implementation
void Delete_queue() { if (front==-1) { printf("\nUnderflow"); return ; } ch = q[front]; printf("\n Element deleted %d:", ch); if(front == rear) { front = -1; rear = -1; } else { if ( front == size-1) front = 0; else front++ ; } }
By Soumi Dutta
Implementation
void Display_queue() { int i; if (front==-1 ) { printf("\nUnderflow"); return ; } if ( rear > front) { for(i = front; i <= rear; i++) printf(" %d \n", q[i]); } else { for(i = front; i < size; i++) printf(" %d \n", q[i]); for(i = 0; i <= rear; i++) printf(" %d \n", q[i]); } }
By Soumi Dutta
Rear Q[4]
Front Q[0] 55 11
Q[3]
44 33 Q[2]
22
Q[1]
Rear Q[0] 15 11
Q[4]
Q[3]
14 13 Q[2]
12
Front Q[1]
DEQUES
A deque is a homogeneous list in which elements can be added or inserted (called push operation) and deleted or removed from both the ends (which is called pop operation). ie; we can add a new element at the rear or front end and also we can remove an element from both front and rear end. Hence it is called Double Ended Queue. The possible operation performed on deque is
Front
-
Rear
77
By Soumi Dutta
65
98
34
23
DEQUES
There are two types of deque depending upon the restriction to perform insertion or deletion operations at the two ends. They are
1. Input restricted deque : An input restricted deque is a deque, which allows insertion at only 1 end, rear end, but allows deletion at both ends, rear and front end of the lists. 1st, 3rd and 4th operations are performed by input-restricted deque .
2. Output restricted deque : An output-restricted deque is a deque, which allows deletion at only one end, front end, but allows insertion at both ends, rear and front
ends, of the lists. 1st, 2nd and 3rd operations are performed by output-restricted
deque.
By Soumi Dutta
77
0 1
65
2
98
3
34
4
23
By Soumi Dutta
77
0 1
65
2
98
3
34
4
23
By Soumi Dutta
By Soumi Dutta
LINKED LIST
By Soumi Dutta
In C, the library function malloc is used to allocate a block of memory on the heap.
The program accesses this block of memory via a pointer that malloc returns. When the memory is no longer needed, the pointer is passed to free which de-allocates the memory so that it can be used for other purposes.
By Soumi Dutta
Type-cast of malloc
malloc returns a void pointer (void *), which indicates that it is a pointer to a region of unknown data type. The lack of a specific pointer type returned from malloc is type-unsafe behavior : malloc allocates based on byte count but not on type.
Example: struct link { int info; struct link *next; }; struct link *start; start = (struct link *)malloc(sizeof(struct link));
By Soumi Dutta
Linked List
1000
11
2000
12
2000 3005 B
3005 13 4005 C
4005
14
NULL
By Soumi Dutta
2. Efficient memory utilization: In linked list (or dynamic) representation, memory is not
pre-allocated. Memory is allocated whenever it is required. And it is De-allocated (or removed) when it is not needed. 3. Insertion and deletion are easier and efficient. Linked list provides flexibility in inserting a data item at a specified position and deletion of a data item from the given position. 4. Many complex applications can be easily carried out with linked list.
Disadvantages:
1. More memory: to store an integer number, a node with integer data and address field is allocated. That is more memory space is needed. 2. Access to an arbitrary data item is little bit cumbersome and also time consuming.
By Soumi Dutta
Single Linked-List
struct link { int info;
Data Link
2000 A
2000 3005 B
3005 13 4005 C
4005
14
NULL D
By Soumi Dutta
Case 1
temp->next=NULL;
else temp->next = start; //Add node start= temp; }
Case 2
Temp 10 Start
20
30
*
10 Start
Temp->next=Start
*
By Soumi Dutta
20
30
20
30
Temp
20
30
40
Temp1
while(temp1->next!= NULL)
temp1 = temp1->next;
temp1->next = temp; //Add node }
Temp->Next=NULL;
By Soumi Dutta
Temp1->Next=Temp;
20
30
p=start;
printf("\n Input the new value: "); temp = (struct link *)malloc(sizeof(struct link)); scanf("%d", &temp->info);
Position = 3
1 2 3
10 Start
* p->next=temp
20
* p
50
30
* temp->next=p-next
temp
// Data Display
void display() 10 * { Start struct link *temp; if(start==NULL) { printf("Empty List\n"); return; } temp=start; while(temp != NULL) { printf(" %d ",temp->info); temp = temp->next; } }
20
30
By Soumi Dutta
free(temp);
} }
temp 10
start 20
*
By Soumi Dutta
25
30
X
*
30
20
25
20
25
X*
temp=p->next;
temp=p->next;
p->next=temp->next; free(temp); }
By Soumi Dutta
p->next=temp->next;
free(temp);
temp
20
*
Start
30
*
p
40
X*
p=temp;
temp = temp->next;
} printf("Deleted Velue: %d\n",temp->info); p->next=NULL; free(temp); //Delete node }
By Soumi Dutta
p->next=NULL; free(temp);
Dynamic Stack
 Stack
 Push  Add Node at the beginning
 Pop  Add Node from the beginning
By Soumi Dutta
1. Input the DATA to be pushed 2. Creat a New Node 3. NewNode DATA = DATA 4. NewNode Next = TOP 5. TOP = NewNode 6. Exit
By Soumi Dutta
2. Else
(a) TEMP = TOP (b) Display The popped element TOP  DATA
Dynamic Queue
 Queue
 Insert  Add Node at the end
 Delete  Add Node from the beginning
By Soumi Dutta
1. Input the DATA element to be pushed 2. Create a New Node 3. NewNode DATA = DATA 4. NewNode Next = NULL 5. If(REAR->Next not equal to NULL) (a) REAR next = NewNode; 6. REAR =NewNode; 7. Exit
By Soumi Dutta
(c) Else
(d) FRONT = NULL; 3. Exit
By Soumi Dutta
two polynomials f(x) and g(x); it can be represented using linked list as
follows
By Soumi Dutta
doubly linked list has three fields: Left Pointer, Right Pointer and DATA.
By Soumi Dutta
A circular doubly linked list has both the successor pointer and predecessor pointer in circular manner as shown in the Fig. 5.34. Implementation of circular doubly linked list is left to the readers.
By Soumi Dutta
SORTING
By Soumi Dutta
BUBBLE SORT
In bubble sort, each element is compared with its adjacent element. If the first element is larger than the second one, then the positions of the elements are interchanged, otherwise it is not changed. Then next element is compared with its adjacent element and the same process is repeated for all the elements in the array until we get a sorted array.
By Soumi Dutta
Steps
Suppose the list of numbers A[1], A[2],  A[n] is an element of array A. The bubble
sort algorithm works as follows:
Step 1: Compare A[1] and A[2] and arrange them in the (or desired) ascending order, so that A[1] < A[2].that is if A[1] is greater than A[2] then interchange the position of data by swap = A[1]; A[1] = A[2]; A[2] = swap. Then compare A[2] and A[3] and arrange them so that A[2] < A[3]. Continue the process until we compare A[N 1] with A[N]. Note: Step1 contains n 1 comparisons i.e., the largest element is bubbled up to the nth position or sinks to the nth position. When step 1 is completed A[N] will contain the largest element.
Step 2: Repeat step 1 with one less comparisons that is, now stop comparison at A [n 1] and possibly rearrange A[N 2] and A[N 1] and so on.Note: in the first pass, step 2 involves n2 comparisons and the second largest element will occupy A[n-1]. And in the second pass, step 2 involves n 3 comparisons and the 3rd largest element will occupy A[n 2] and so on. Step n 1: compare A[1]with A[2] and arrange them so that A[1] < A[2] After n 1 steps, the array will be a sorted array in increasing (or
ascending) order.
By Soumi Dutta
Example
The following figures will depict the various steps (or PASS) involved in the sorting of an array of 5 elements. The elements of an array A to be sorted are: 42, 33, 23, 74, 44,66,11
No of Elements : 7
By Soumi Dutta
Example
Step 2: 33, 23, 42, 44,66,11,74
Pass 1: 23, 33, 42, 44,66,11,74 Pass 2: 23, 33, 42, 44,66,11,74 Pass 3: 23, 33, 42, 44,66,11,74 Pass 4: 23, 33, 42, 44,66,11,74 Pass 5: 23, 33, 42, 44,11,66,74 No of Elements : N= 7 Step No : S=2 No of Pass = N S = 5
By Soumi Dutta
Example
Step 4: 23, 33, 42, 11, 44, 66,74
Pass 1: 23, 33, 42, 11, 44, 66, 74 Pass 2: 23, 33, 42, 11, 44, 66, 74 Pass 3: 23, 33, 11, 42, 44, 66, 74
By Soumi Dutta
SELECTION SORT
Selection sort algorithm finds the smallest element of the array and interchanges it with the
element in the first position of the array. Then it finds the second smallest element from the remaining elements in the array and places it in the second position of the array and so on. Let A be a linear array of n numbers, A [1], A [2], A [3],...... A [n].
Step 1: Find the smallest element in the array of n numbers A[1], A[2], ...... A[n]. Let LOC is the
location of the smallest number in the array. Then interchange A[LOC] and A[1] by swap = A[LOC]; A[LOC] = A[1]; A[1] = Swap. Step 2: Find the second smallest number in the sub list of n  1 elements A [2] A [3] ...... A [n  1]
Again A [LOC] is the smallest element in the remaining array and LOC the corresponding
location then interchange A [LOC] and A [2].Now A [1] and A [2] is sorted, since A [1] less than or equal to A [2]. Step 3: Repeat the process by reducing one element each from the array
Step n  1: Find the n  1 smallest number in the sub array of 2 elements (i.e., A(n1), A (n)).
Consider A [LOC] is the smallest element and LOC is its corresponding position. Then interchange A [LOC] and A(n  1). Now the array A [1], A [2], A [3], A [4],..A [n] will be a sorted array.
By Soumi Dutta
Example
The following figures will depict the various steps (or PASS) involved in the sorting of an array of 5 elements. The elements of an array A to be sorted are: Starting : 42, 33, 23, 74, 44
Pass 1: 42, 33, 23, 74, 44 Pass 2: 23, 33, 42, 74, 44 Pass 3: 23, 33, 42, 74, 44 Pass 4: 23, 33, 42, 74, 44 Final : 23, 33, 42, 44, 74
//Smallest LOC=2 ; Swap (42, 23) //Smallest LOC=1; No Swap //Smallest LOC=2 ; No Swap //Smallest LOC=3 ; Swap (74, 44)
By Soumi Dutta
INSERTION SORT
Insertion sort algorithm sorts a set of values by inserting values. Compare the second element with first, if the first element is greater than second, place it before the first one. Otherwise place is just after the first one.
Compare the third value with second. If the third value is greater than the
second value then place it just after the second. Otherwise place the second value to the third place. And compare third value with the first value. If the third value is greater than the first value place the third value to second place, otherwise place the first value to second place. And place the third value to first place and so on.
Let A be a linear array of n numbers A [1], A [2], A [3], ...... A[n]. The algorithm scan the array A from A [1] to A [n], by inserting each element A[k], into the proper position of the previously sorted sub list. A [1], A [2], A [3], ...... A [k  1]
By Soumi Dutta
STEPS
 
Step 1: As the single element A [1] by itself is sorted array. Step 2: A [2] is inserted either before or after A [1] by comparing it so that A[1], A[2] is sorted array.
Step 3: A [3] is inserted into the proper place in A [1], A [2], that is A [3] will be
compared with A [1] and A [2] and placed before A [1], between A [1] and A [2], or after A [2] so that A [1], A [2], A [3] is a sorted array.
Step 4: A [4] is inserted in to a proper place in A [1], A [2], A [3] by comparing it; so that A [1], A [2], A [3], A [4] is a sorted array.
Step 5: Repeat the process by inserting the element in the proper place in array Step n : A [n] is inserted into its proper place in an array A [1], A [2], A [3], ...... A [n 1] so that A [1], A [2], A [3], ...... ,A [n] is a sorted array.
By Soumi Dutta
Example
The following figures will depict the various steps (or PASS) involved in the sorting of an array of 5 elements. The elements of an array A to be sorted are:
Step 1 : Pass 1: 33, 42, 23, 74, 44 Step 2 : Pass 1: 33, 23, 42, 74, 44 Pass 2: 23, 33, 42, 74, 44
By Soumi Dutta
Example
Step 3 : Pass 1: 23, 33, 42, 74, 44 Pass 2: 23, 33, 42, 74, 44 Pass 3: 23, 33, 42, 74, 44 // Loc 3: Temp=74 ; NO Swap // NO Swap // NO Swap
Step 4 : Pass 1: 33, 23, 42, 44, 74 Pass 2: 23, 33, 42, 44, 74 Pass 3: 23, 33, 42, 44, 74 Pass 4: 23, 33, 42, 44, 74
By Soumi Dutta
Divide-and-conquer algorithms
The divide-and-conquer strategy solves a problem by: 1. Breaking it into sub problems that are themselves smaller instances of the same type of problem
The real work is done piecemeal, in three different places: in the partitioning of
problems into sub problems; at the very tail end of the recursion, when the sub problems are so small that they are solved outright; and in the gluing together of partial answers. These are held together and coordinated by the algorithm's core recursive structure.
By Soumi Dutta
QUICK SORT
It is one of the widely used sorting techniques and it is also called the partition exchange sort. Quick sort is an efficient algorithm and it passes a very good time complexity in average case.
The quick sort algorithm works by partitioning the array to be sorted. And each partitions are internally sorted recursively. In partition the first element of an array is chosen as a key value. This key value can be the first element of an array. That is, if A is an array then key = A (0), and rest of the elements are grouped into two portions such that,
By Soumi Dutta
Quick SORT
Unsorted Array x[7]: 42, 33, 23, 74, 44, 67, 49 First= 0, Last = 6 Function Quicksort(int x[10],int first,int last) As First < Last :::: Pivot=First=0, i=First=0, j=Last=6 While (i<j) For i=0 &j=6 Step 1: (x[i]<=x[pivot] & i<last): i=1 Step 2: (x[i]<=x[pivot] & i<last): i=2 Step 3: (x[i]<=x[pivot] & i<last): i=3 S t e p 4 : (x[j]>x[pivot]) : j=5 S t e p 5 : (x[j]>x[pivot]) : j=4 S t e p 6 : (x[j]>x[pivot]) : j=3 S t e p 7 : (x[j]>x[pivot]) : j=2 Now i=3 & j=2 If i<j then swap x[i] and x[j] End While 23, 33,42, 74, 44, 67, 49 Swap x[pivot] & x[j] quicksort(x,0,1); quicksort(x,3,6);
By Soumi Dutta
Coding
void quicksort(int x[10],int first,int last){ int pivot,j,temp,i; if(first<last){ pivot=first; i=first; j=last; while(i<j){ while(x[i]<=x[pivot]&&i<last) i++; while(x[j]>x[pivot]) j--; if(i<j){ temp=x[i]; x[i]=x[j]; x[j]=temp; } } temp=x[pivot]; x[pivot]=x[j]; x[j]=temp; quicksort(x,first,j-1); quicksort(x,j+1,last); } }
By Soumi Dutta
Comparison of algorithms
In this table, n is the number of records to be sorted. The columns "Average" and "Worst" give the time complexity in each case, under the assumption that the length of each key is constant, and that therefore all comparisons, swaps, and other needed operations can proceed in constant time. "Memory" denotes the amount of auxiliary storage needed beyond that used by the list itself, under the same assumption. The time complexity of quick sort can be calculated for any of the following case. It is usually measured by the number f (n) of comparisons required to sort n elements.
By Soumi Dutta
Merge Sort
Merging is the process of combining two or more sorted array into a third sorted array. Divide the array into approximately n/2 sub-arrays of size two and set the element in each sub array. Merging each sub-array with the adjacent sub-array will get another sorted subarray of size four. Repeat this process until there is only one array remaining of size n. Since at any time the two arrays being merged are both sub-arrays of A, lower and upper bounds are required to indicate the sub-arrays of a being merged. l1 and u1 represents the lower and upper bands of the first sub-array and l2 and u2 represents the lower and upper bands of the second sub-array respectively. Let A be an array of n number of elements to be sorted A[1], A[2] ...... A[n]. Step 1: Divide the array A into approximately n/2 sorted sub-array of size 2. i.e., the elements in the (A [1], A [2]), (A [3], A [4]), (A [k], A [k + 1]), (A [n  1], A [n]) sub-arrays are in sorted order.
Step 2: Merge each pair of pairs to obtain the following list of sorted sub-array of size.4; the elements in the sub-array are also in the sorted order. (A [1], A [2], A [3], A [4)),...... (A [k  1], A [k], A [k + 1], A [k + 2]),...... (A [n  3], A [n  2], A [n  1], A [n].
Step 3: Repeat the step 2 recursively until there is only one sorted array of size n.
By Soumi Dutta
Merge Sort
By Soumi Dutta
SEARCHING
By Soumi Dutta
SEARCHING
Searching is a process of checking and finding an element from a list of elements. There are several types of searching techniques;
By Soumi Dutta
TIME COMPLEXITY
Time Complexity of the linear search is found by number of comparisons made in searching a record.
In the best case, the desired element is present in the first position of the
array, i.e., only one comparison is made. So f (n) = O(1).
In the Average case, the desired element is found in the half position of the
array, then f (n) = O[(n + 1)/2].
But in the worst case the desired element is present in the nth (or last)
position of the array, so n comparisons are made. So f (n) = O(n).
By Soumi Dutta
BINARY SEARCH
Binary search is an extremely efficient algorithm when it is compared to linear search. In Binary search the given array is a sorted one, otherwise first we have to sort the array elements. Then apply the following conditions to search a data.
1.
Find the middle element of the array (i.e., n/2 is the middle element if the
array or the sub-array contains n elements).
2.
Compare the middle element with the data to be searched, then there
By Soumi Dutta
By Soumi Dutta
By Soumi Dutta
TIME COMPLEXITY
Time Complexity is measured by the number f (n) of comparisons to locate
data in A, which contain n elements. Observe that in each comparison the size
of the search area is reduced by half. Hence in the worst case, at most log2 n comparisons required. So f (n) = O([log2 n ]+1).
By Soumi Dutta
INTERPOLATION SEARCH
Another technique for searching an ordered array is called interpolation search. This method is even more efficient than binary search, if the elements are uniformly distributed (or sorted) in an array A. Consider an array A of n elements and the elements are uniformly distributed (or the elements are arranged in a sorted array). Initially, as in binary search, low is set to 0 and high is set to n  1. Now we are searching an element key in an array between A[low] and A[high]. The key would be expected to be at mid, which is an approximately position. mid = low + (high  low)  ((key  A[low])/(A[high]  A[low])) If key is lower than A[mid], reset high to mid1; else reset low to mid+1. Repeat the process
By Soumi Dutta
Example
Interpolation search can be explained with an example below. Consider 7 numbers : 2, 25, 35, 39, 40, 47, 50 CASE 1: Say we are searching 50 from the array Here n = 7 Key = 50 low = 0 high = n  1 = 6 mid = 0+(60)  ((502)/(502)) = 6  (48/48) =6 if (key == A[mid])  key == A[6]  50 == 50  key is found.
By Soumi Dutta
CASE 2: Say we are searching 25 from the array Here n = 7 Key = 25 low = 0 high = n 1 = 6 mid = 0 + (60) ((252)/(502)) = 6 (23/48) = 2.875 Here we consider only the integer part of the mid i.e., mid = 2 if (key == A[mid]) key == A[2] 25 == 25 key is found.
By Soumi Dutta
CASE 3: Say we are searching 34 from the array Here n = 7 Key = 34 low = 0 high = n  1 = 6 mid = 0 + (6  0)  ((34  2)/(34  2)) = 6  (32/48) =4 if(key < A[mid])  key < A[4]  34 < 40 so reset high = mid1 3 low = 0 high = 3 Since(low < high) mid = 0+(30)  ((342)/(392)) = 3  (32/37) = 2.59 Here we consider only the integer part of the mid i.e., mid = 2
By Soumi Dutta
if (key < A[mid])  key < A[2]  34 < 35 so reset high = mid1 1 low = 0 high = 1 Since (low < high) mid = 0+(10)  ((342)/(252)) = 3  (32/23) =1 here (key > A[mid])  key > A[1]  34 > 25 so reset low = mid+1 2 low = 2 high = 1 Since (low > high) DISPLAY  The key is not in the array STOP
By Soumi Dutta
Algorithm Suppose A be array of sorted elements and key is the elements to be searched and low represents the lower bound of the array and high represents higher bound of the array.
1. Input a sorted array of n elements and the key to be searched 2. Initialize low = 0 and high = n 1 3. Repeat the steps 4 through 7 until if(low < high) 4. Mid = low + (high low) ((key A[low]) / (A[high] A[low])) 5. If(key < A[mid]) (a) high = mid1 6. Else if (key > A[mid]) (a) low = mid + 1 7. Else (a) DISPLAY The key is not in the array (b) STOP 8. STOP
By Soumi Dutta
TREE
By Soumi Dutta
Tree
A tree is an ideal data structure for representing hierarchical data. A tree can be theoretically defined as a finite set of one or more data items (or nodes) such that : 1. There is a special node called the root of the tree. 2. Removing nodes (or data item) are partitioned into number of mutually exclusive (i.e., disjoined) subsets each of which is itself a tree, are called sub tree.
By Soumi Dutta
Terminology
A
node is a structure which may contain a value . Each node in a tree has zero or more child nodes, which are below it in the tree. A node that has a child is called the child's parent node . A node has at most one parent.
internal node (also known as an inner node or branch node) is any node of a tree that has child nodes. Similarly, an external node (also known as an outer node, leaf node, or terminal node) is any node that does not have child nodes. topmost node in a tree is called the root node. Being the topmost node, the root node will not have a parent.
An
The
The depth of a node n is the length of the path from the root to the node. The
set of all nodes at a given depth is sometimes called a level of the tree. The root node is at depth zero.
The depth (or height) of a tree is the length of the path from the root to the deepest node in the tree. A (rooted) tree with only one node (the root) has a depth of zero.
By Soumi Dutta
Binary Tree
In computer science, a binary tree is a tree data structure in which each node has at most two child nodes, usually distinguished as "left" and "right". Nodes with children are parent nodes, and child nodes may contain references to their parents. Outside the tree, there is often a reference to the "root" node (the ancestor of all nodes), if it exists. Any node in the data structure can be reached by starting at root node and repeatedly following references to either the left or right
child. A tree which does not have any node other than root node is called a null
tree.
By Soumi Dutta
Terminology
A
full binary tree is a perfect binary tree in which all leaves are at the same
depth or same level, and in which every parent has two children. (This is ambiguously also called a complete binary tree.)
complete binary tree is a binary tree in which every level, except possibly
the last, is completely filled, and all nodes are as far left as possible.[
By Soumi Dutta
By Soumi Dutta
By Soumi Dutta
By Soumi Dutta
By Soumi Dutta
To traverse a non-empty binary tree in pre order following steps one to be processed 1. Visit the root node 2. Traverse the left sub tree in preorder 3. Traverse the right sub tree in preorder That is, in preorder traversal, the root node is visited (or processed) first, before traveling through left and right sub trees recursively. It can be implement in C/C++ function as below : void preorder (Node * Root) { If (Root != NULL) { printf (%d\n,Root  Info); preorder(Root  L child); preorder(Root  R child); } }
By Soumi Dutta
By Soumi Dutta
The in order traversal of a non-empty binary tree is defined as follows : 1. Traverse the left sub tree in order 2. Visit the root node 3. Traverse the right sub tree in order In order traversal, the left sub tree is traversed recursively, before visiting the root. After visiting the root the right sub tree is traversed recursively, in order fashion. The procedure for an in order traversal is given below : void inorder (NODE *Root) { If (Root != NULL) { inorder(Root  L child); printf (%d\n,Root  info); inorder(Root  R child); } }
By Soumi Dutta
By Soumi Dutta
By Soumi Dutta
By Soumi Dutta
By Soumi Dutta
DELETING A NODE
First search and locate the node to be deleted. Then any one of the following conditions arises : 1. The node to be deleted has no children :: Find & delete the node.
2. The node has exactly one child (or sub tress, left or right sub tree) 3. The node has two children (or two sub tress, left and right sub tree)
By Soumi Dutta
DELETING A NODE
First search and locate the node to be deleted. Then any one of the following conditions arises : 1. The node to be deleted has no children :: Find & delete the node. 2. The node has exactly one child (or sub tress, left or right sub tree) : Replace it by its child node.
3. The node has two children (or two sub tress, left and right sub tree)
By Soumi Dutta
DELETING A NODE
First search and locate the node to be deleted. Then any one of the following conditions arises : 1. The node to be deleted has no children :: Find & delete the node. 2. The node has exactly one child (or sub tress, left or right sub tree) : Replace it by its child node. 3. The node has two children (or two sub tress, left and right sub tree) : Replace it by inorder successor.
By Soumi Dutta
AVL TREE
Right-Right case and Right-Left case: If the balance factor of P is -2 then the right subtree outweighs the left subtree of the given node, and the balance factor of the right child (R) must be checked. The left rotation with P as the root is necessary.  If the balance factor of R is -1, a single left rotation (with P as the root) is needed (RightRight case).  If the balance factor of R is +1, two different rotations are needed. The first rotation is a right rotation with R as the root. The second is a left rotation with P as the root (RightLeft case).
Left-Left case and Left-Right case:  If the balance factor of P is 2, then the left subtree outweighs the right subtree of the given node, and the balance factor of the left child (L) must be checked. The right rotation with P as the root is necessary.  If the balance factor of L is +1, a single right rotation (with P as the root) is needed (LeftLeft case).  If the balance factor of L is -1, two different rotations are needed. The first rotation is a left rotation with L as the root. The second is a right rotation with P as the root (LeftRight case).
By Soumi Dutta
BFS
In graph theory, breadth-first search (BFS) is a strategy for searching in a graph when
search is limited to essentially two operations: (a) visit and inspect a node of a graph; (b) gain access to visit the nodes that neighbor the currently visited node. The BFS begins at a root node and inspect all the neighboring nodes. Then for each of those neighbor nodes in turn, it inspects their neighbor nodes which were unvisited, and so on.
The algorithm uses a queue data structure to store intermediate results as it traverses the
graph, as follows: 1. Enqueue the root node 2. Dequeue a node and examine it If the element sought is found in this node, quit the search and return a result. Otherwise enqueue any successors (the direct child nodes) that have not yet been discovered.
3. If the queue is empty, every node on the graph has been examined  quit the search
and return "not found". 4. If the queue is not empty, repeat from Step 2.
By Soumi Dutta
DFS
Depth-first search (DFS) is an algorithm for traversing or searching a tree, tree
structure, or graph. One starts at the root (selecting some node as the root in the graph case) and explores as far as possible along each branch before
backtracking.
A depth-first search starting at A, assuming that the left edges in the shown graph are chosen before right edges, and assuming the search remembers previously
visited nodes and will not repeat them (since this is a small graph), will visit the
nodes in the following order: A, B, D, F, E, C, G.
By Soumi Dutta