-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinsertion-sort.js
29 lines (25 loc) · 792 Bytes
/
insertion-sort.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
const { swap } = require('./sorting-common');
// tag::sort[]
/**
* Sorting by insertion - Look for bigger numbers on the left side
*
* It starts from the 2nd element,
* and it tries to find any element (to the left)
* that could be bigger than the current index.
* It will move all the elements that are bigger
* and insert the current element where it belongs.
*
* Runtime: O(n^2)
* @param {Array|Set} collection elements to be sorted
*/
function insertionSort(collection) {
const array = Array.from(collection); // <1>
for (let right = 1; right < array.length; right++) { // <2>
for (let left = right; array[left - 1] > array[left]; left--) { // <3>
swap(array, left - 1, left); // <4>
}
}
return array;
}
// end::sort[]
module.exports = insertionSort;