Data Structures
Unit-1
Chapter-3
3.Sorting
1. Insertion Sort.
2. Selection Sort.
3. Exchange- Bubble and Quick Sort.
4. Distribution-Radix Sort.
5. Merging- Merge Sort.
1. Insertion Sort
• A Sorting Algorithm is used to rearrange a given array or list of elements
according to a comparison operator on the elements. The comparison operator is
used to decide the new order of elements in the respective data structure.
• Insertion Sort:-
• Simple implementation
• Efficient for small data sets
• Adaptive, i.e., it is appropriate for data sets that are already substantially
sorted.
Working Procedure of Insertion Sort:-
• Consider the following Unsorted Array:-
• Initially, the first two elements are compared in insertion sort.
• Here, 31 is greater than 12. That means both elements are already in
ascending order. So, for now, 12 is stored in a sorted sub-array.
• Now, move to the next two elements and compare them.
• Here, 25 is smaller than 31. So, 31 is not at correct position. Now, swap 31 with 25.
Along with swapping, insertion sort will also check it with all elements in the sorted
array.
• For now, the sorted array has only one element, i.e. 12. So, 25 is greater than 12.
Hence, the sorted array remains sorted after swapping.
• Both 31 and 8 are not sorted. So, swap them.
• After swapping, elements 25 and 8 are unsorted. So, swap them.
• Now, elements 12 and 8 are unsorted. So, swap them too.
• Now, the sorted array has three items that are 8, 12 and 25. Move to the next items that
are 31 and 32.
• Hence, they are already sorted. Now, the sorted array includes 8, 12, 25 and 31.
• Move to the next elements that are 32 and 17.
• 17 is smaller than 32. So, swap them.
• Swapping makes 31 and 17 unsorted. So, swap them too.
• Now, swapping makes 25 and 17 unsorted. So, perform swapping
again.
• Now, the array is completely sorted.
Insertion Sort Algorithm
Step 1 - If the element is the first element, assume that it is already
sorted. Return 1.
Step2 - Pick the next element, and store it separately in a key.
Step3 - Now, compare the key with all elements in the sorted array.
Step 4 - If the element in the sorted array is smaller than the current
element, then move to the next element. Else, shift greater elements in
the array towards the right.
Step 5 - Insert the value.
Step 6 - Repeat until the array is sorted.
Insertion sort complexity
1. Time Complexity
Best Case Complexity - It occurs when there is no sorting required, i.e. the array is
already sorted. The best-case time complexity of insertion sort is O(n).
Average Case Complexity - It occurs when the array elements are in jumbled order
that is not properly ascending and not properly descending. The average case time
complexity of insertion sort is O(n2).
Worst Case Complexity - It occurs when the array elements are required to be
sorted in reverse order. That means suppose you have to sort the array elements in
ascending order, but its elements are in descending order. The worst-case time
complexity of insertion sort is O(n2).
2. Space Complexity
O(1)
2. Selection Sort
Selection sort is generally used when :-
• A small array is to be sorted.
• Swapping cost doesn't matter.
• It is compulsory to check all elements.
• Working Procedure of Selection Sort:-
• Consider the following unsorted array:-
• Now, for the first position in the sorted array, the entire array is to be
scanned sequentially.
Selection Sort Algorithm
• SELECTION SORT(arr, n)
• Step 1: Repeat Steps 2 and 3 for i = 0 to n-1
• Step 2: CALL SMALLEST(arr, i, n, pos)
• Step 3: SWAP arr[i] with arr[pos]
• [END OF LOOP]
• Step 4: EXIT
• SMALLEST (arr, i, n, pos)
• Step 1: [INITIALIZE] SET SMALL = arr[i]
• Step 2: [INITIALIZE] SET pos = i
• Step 3: Repeat for j = i+1 to n
• if (SMALL > arr[j])
• SET SMALL = arr[j]
• SET pos = j
• [END OF if]
• [END OF LOOP]
• Step 4: RETURN pos
Selection sort complexity
1. Time Complexity
Best Case Complexity - It occurs when there is no sorting required, i.e. the array is
already sorted. The best-case time complexity of selection sort is O(n2).
Average Case Complexity - It occurs when the array elements are in jumbled order
that is not properly ascending and not properly descending. The average case time
complexity of selection sort is O(n2).
Worst Case Complexity - It occurs when the array elements are required to be
sorted in reverse order. That means suppose you have to sort the array elements in
ascending order, but its elements are in descending order. The worst-case time
complexity of selection sort is O(n2).
2. Space Complexity
Space Complexity
O(1)
3. Exchange Sort
• Bubble Sort.
• Quick Sort.
3.1 Bubble Sort
• Bubble sort works on the repeatedly swapping of adjacent elements until they
are not in the intended order. It is called bubble sort because the movement of
array elements is just like the movement of air bubbles in the water. Bubbles in
water rise up to the surface; similarly, the array elements in bubble sort move to
the end in each iteration.
• Bubble short is majorly used where :–
• complexity does not matter
• simple and short code is preferred
• Working Procedure of Bubble sort Algorithm:-
• To understand the working of bubble sort algorithm, let's take an unsorted
array.Let the elements of array are –
• First Pass:-
• Sorting will start from the initial two elements.
• Second Pass:-
• The same process will be followed for second iteration.
• Third Pass:-
• Fourth pass:-
• Similarly, after the fourth iteration, the array will be –
• Hence, there is no swapping required, so the array is completely sorted.
Bubble sort Algorithm
begin BubbleSort(arr)
for all array elements
if arr[i] > arr[i+1]
swap(arr[i], arr[i+1])
end if
end for
return arr
end BubbleSort
Bubble sort complexity
• Best Case Complexity - It occurs when there is no sorting required, i.e. the array is
already sorted. The best-case time complexity of bubble sort is O(n).
• Average Case Complexity - It occurs when the array elements are in jumbled
order that is not properly ascending and not properly descending. The average
case time complexity of bubble sort is O(n2).
• Worst Case Complexity - It occurs when the array elements are required to be
sorted in reverse order. That means suppose you have to sort the array elements
in ascending order, but its elements are in descending order. The worst-case time
complexity of bubble sort is O(n2).
• The space complexity of bubble sort is O(1).
3.2 Quick Sort
• Quicksort is the widely used sorting algorithm that follows the divide and
conquer approach. Divide and conquer is a technique of breaking down the
algorithms into subproblems, then solving the subproblems, and combining the
results back together to solve the original problem.
• Divide: In Divide, first pick a pivot element. After that, partition or rearrange the
array into two sub-arrays such that each element in the left sub-array is less than
or equal to the pivot element and each element in the right sub-array is larger
than the pivot element.
• Conquer: Recursively, sort two subarrays with Quicksort.
• Combine: Combine the already sorted array.
• Choosing the pivot:-
• Pivot can be random, i.e. select the random pivot from the
given array.
• Pivot can either be the rightmost element of the leftmost
element of the given array.
• Select median as the pivot element.
• Working Procedure of Quick Sort Algorithm:-
• To understand the working of quick sort, let's take an unsorted array. Let the
elements of array are –
• In the given array, we consider the leftmost element as pivot. So, in this case,
a[left] = 24, a[right] = 27 and a[pivot] = 24. Since, pivot is at left, so algorithm
starts from right and move towards left.
• Now, a[pivot] < a[right], so algorithm moves forward one position towards
left, i.e. -
• Now, a[left] = 24, a[right] = 19, and a[pivot] = 24.
• Because, a[pivot] > a[right], so, algorithm will swap a[pivot] with a[right], and
pivot moves to right, as -
• Now, a[left] = 19, a[right] = 24, and a[pivot] = 24. Since, pivot is at right, so
algorithm starts from left and moves to right.
• As a[pivot] > a[left], so algorithm moves one position to right as –
• Now, a[left] = 9, a[right] = 24, and a[pivot] = 24. As a[pivot] > a[left], so
algorithm moves one position to right as -
• Now, a[left] = 29, a[right] = 24, and a[pivot] = 24. As a[pivot] < a[left], so,
swap a[pivot] and a[left], now pivot is at left, i.e. –
• Since, pivot is at left, so algorithm starts from right, and move to left. Now,
a[left] = 24, a[right] = 29, and a[pivot] = 24. As a[pivot] < a[right], so algorithm
moves one position to left, as -
• Now, a[pivot] = 24, a[left] = 24, and a[right] = 14. As a[pivot] > a[right], so,
swap a[pivot] and a[right], now pivot is at right, i.e. –
• Now, a[pivot] = 24, a[left] = 14, and a[right] = 24. Pivot is at right, so the
algorithm starts from left and move to right.
• Now, a[pivot] = 24, a[left] = 24, and a[right] = 24. So, pivot, left and right are
pointing the same element. It represents the termination of
procedure.Element 24, which is the pivot element is placed at its exact
position.
• Elements that are right side of element 24 are greater than it, and the
elements that are left side of element 24 are smaller than it.
• Now, in a similar manner, quick sort algorithm is separately applied to the left
and right sub-arrays. After sorting gets done, the array will be -
Quick Sort Algorithm
PARTITION (array A, start, end)
QUICKSORT (array A, start, end)
{
{
1 pivot ? A[end]
1 if (start < end)
2 i ? start-1
2{
3 for j ? start to end -1 {
3 p = partition(A, start, end)
4 do if (A[j] < pivot) {
4 QUICKSORT (A, start, p - 1)
5 then i ? i + 1
5 QUICKSORT (A, p + 1, end)
6 swap A[i] with A[j]
6}
7 }}
}
8 swap A[i+1] with A[end]
9 return i+1
}
Quicksort complexity
• Best Case Complexity - In Quicksort, the best-case occurs when the pivot element
is the middle element or near to the middle element. The best-case time
complexity of quicksort is O(n*logn).
• Average Case Complexity - It occurs when the array elements are in jumbled
order that is not properly ascending and not properly descending. The average
case time complexity of quicksort is O(n*logn).
• Worst Case Complexity - In quick sort, worst case occurs when the pivot element
is either greatest or smallest element. Suppose, if the pivot element is always the
last element of the array, the worst case would occur when the given array is
sorted already in ascending or descending order. The worst-case time complexity
of quicksort is O(n2).
• The space complexity of quicksort is O(n*logn).
4. Distribution-Radix Sort.
• Radix Sort:-
Radix sort is the linear sorting algorithm that is used for integers. In
Radix sort, there is digit by digit sorting is performed that is started from the
least significant digit to the most significant digit.
The steps used in the sorting of radix sort are listed as follows -
• First, we have to find the largest element (suppose max) from the given
array. Suppose 'x' be the number of digits in max. The 'x' is calculated
because we need to go through the significant places of all elements.
• After that, go through one by one each significant place. Here, we have to
use any stable sorting algorithm to sort the digits of each significant place.
• Working Procedure of Radix sort Algorithm:-
To understand the working of bubble sort algorithm, let's take an unsorted
array.Let the elements of array are –
In the given array, the largest element is 736 that have 3 digits in it. So, the loop will
run up to three times (i.e., to the hundreds place). That means three passes are required to
sort the array.
Pass 1:
• After the first pass, the array elements are –
• Pass 2:-
• After the second pass, the array elements are –
• Pass 3:-
• After the third pass, the array elements are -
Radix sort Algorithm
radixSort(arr)
max = largest element in the given array
d = number of digits in the largest element (or, max)
Now, create d buckets of size 0 - 9
for i -> 0 to d
sort the array elements using counting sort (or any stable sort)
according to the digits at
the ith place
Radix sort complexity
• Best Case Complexity - It occurs when there is no sorting required, i.e. the
array is already sorted. The best-case time complexity of Radix sort is Ω(n+k).
• Average Case Complexity - It occurs when the array elements are in jumbled
order that is not properly ascending and not properly descending. The
average case time complexity of Radix sort is θ(nk).
• Worst Case Complexity - It occurs when the array elements are required to be
sorted in reverse order. That means suppose you have to sort the array
elements in ascending order, but its elements are in descending order. The
worst-case time complexity of Radix sort is O(nk).
• The space complexity of Radix sort is O(n + k).
5. Merging- Merge Sort.
• Merge sort is the sorting technique that follows the divide and conquer
approach.
• Merge sort is similar to the quick sort algorithm as it uses the divide and conquer
approach to sort the elements. It is one of the most popular and efficient sorting
algorithm. It divides the given list into two equal halves, calls itself for the two
halves and then merges the two sorted halves. We have to define the merge()
function to perform the merging.
• The sub-lists are divided again and again into halves until the list cannot be
divided further. Then we combine the pair of one element lists into two-element
lists, sorting them in the process. The sorted two-element pairs is merged into
the four-element lists, and so on until we get the sorted list.
• Working Procedure of Merge sort Algorithm:-
To understand the working of Merge sort, let's take an unsorted array. Let the
elements of array are –
Now, the array is completely sorted.
Merge Sort Algorithm
MERGE_SORT(arr, beg, end)
if beg < end
set mid = (beg + end)/2
MERGE_SORT(arr, beg, mid)
MERGE_SORT(arr, mid + 1, end)
MERGE (arr, beg, mid, end)
end of if
END MERGE_SORT
Merge sort complexity
• Best Case Complexity - It occurs when there is no sorting required, i.e. the array is
already sorted. The best-case time complexity of merge sort is O(n*logn).
• Average Case Complexity - It occurs when the array elements are in jumbled
order that is not properly ascending and not properly descending. The average
case time complexity of merge sort is O(n*logn).
• Worst Case Complexity - It occurs when the array elements are required to be
sorted in reverse order. That means suppose you have to sort the array elements
in ascending order, but its elements are in descending order. The worst-case time
complexity of merge sort is O(n*logn).
• The space complexity of merge sort is O(n).