Data Structure - Bubble Sort Algorithm
Data Structure - Bubble Sort Algorithm
Data Structure - Bubble Sort Algorithm
Algorithm
We take an unsorted array for our example. Bubble sort takes Ο(n 2) time so
we're keeping it short and precise.
Bubble sort starts with very first two elements, comparing them to check
which one is greater.
We find that 27 is smaller than 33 and these two values must be swapped.
Next we compare 33 and 35. We find that both are in already sorted positions.
Then we move to the next two values, 35 and 10.
We know then that 10 is smaller 35. Hence they are not sorted.
We swap these values. We find that we have reached the end of the array. After
one iteration, the array should look like this −
To be precise, we are now showing how an array should look like after each
iteration. After the second iteration, it should look like this −
Notice that after each iteration, at least one value moves at the end.
And when there's no swap required, bubble sorts learns that an array is
completely sorted.
Now we should look into some practical aspects of bubble sort.
Algorithm
begin BubbleSort(list)
swap(list[i], list[i+1])
end if
end for
return list
end BubbleSort
Pseudocode
We observe in algorithm that Bubble Sort compares each pair of array element
unless the whole array is completely sorted in an ascending order. This may
cause a few complexity issues like what if the array needs no more swapping
as all the elements are already ascending.
To ease-out the issue, we use one flag variable swapped which will help us see
if any swap has happened or not. If no swap has occurred, i.e. the array
requires no more processing to be sorted, it will come out of the loop.
loop = list.count;
swapped = false
/* swap them */
swapped = true
end if
end for
/*if no number was swapped that means
break
end if
end for
Implementation
One more issue we did not address in our original algorithm and its
improvised pseudocode, is that, after every iteration the highest values settles
down at the end of the array. Hence, the next iteration need not include already
sorted elements. For this purpose, in our implementation, we restrict the inner
loop to avoid already sorted values.