JavaScript: DHTML Insertion Sort
This page demonstrates the Insertion Sort algorithm by applying it to the below HTML table - sorting rows by the values in each column.
Working Demonstration
Use the controls under the table to apply different sort orders. The script will rearrange the rows (too quick to be seen) according to the insertion sort algorithm which involves repeated movements.
id | colour | random |
---|---|---|
1 | green | 214 |
2 | red | 706 |
3 | orange | 767 |
4 | yellow | 316 |
5 | yellow | 881 |
6 | blue | 732 |
7 | red | 849 |
8 | purple | 351 |
9 | orange | 613 |
10 | orange | 662 |
11 | blue | 194 |
12 | purple | 202 |
13 | purple | 383 |
14 | red | 185 |
15 | purple | 320 |
16 | red | 6 |
17 | blue | 451 |
18 | blue | 664 |
19 | red | 977 |
20 | blue | 328 |
How does it work?
For a more detailed discussion on the sorting process, you can refer to the Bubble Sort page. The only difference between the two is the actual sorting algorithm, with the Insertion Sort, in theory, being a little bit faster:
/* global variables */
var parent = null; /* parent node */
var items = new Array(); /* array of 'child' nodes */
var col = 0; /* column for sorting */
function sortTable(tableid, n, desc)
{
parent = document.getElementById(tableid);
col = n;
if(parent.nodeName != "TBODY") {
parent = parent.getElementsByTagName("TBODY")[0];
}
if(parent.nodeName != "TBODY") {
return false;
}
/* assert: parent is now a TBODY node */
items = parent.getElementsByTagName("TR");
var N = items.length;
/* insertion sort */
for(var j=1; j < N; j++) {
for(var i=j; i > 0 && compare(get(i), get(i-1), desc); i--) {
exchange(i, i-1);
}
}
}
The compare, get and exchange functions are common to all the different sorting algorithm implementations and can be found documented here.
For more advanced (and complicated) sorting techniques, see the Shell Sort and Quick Sort demonstrations.
Related Articles - Sorting Algorithms
- JavaScript DHTML Sorting Algorithms
- JavaScript DHTML Sorting Using OOP - Example 1
- JavaScript DHTML Insertion Sort
- JavaScript Sorting Algorithm Comparison
- JavaScript DHTML Quick Sort
- JavaScript DHTML Bubble Sort
- JavaScript DHTML Shell Sort
- PHP Sorting Arrays of Arrays
- PHP Sorting SimpleXMLElement Object arrays