insertionSort<E> function
Sorts the list
of numbers using the
insertion sort algorithm.
Parameters
list
is any list of items to be sorted.- To perform partial sorting, you can specify the
begin
orend
. begin
is the start index of the range to be sorted.- If
begin
is negative, range starts at the 0 - If
begin
is not below the length of thelist
, range will be empty. end
is the final index if the range to be sorted. It is exclusive.- If
end
is above the length of thelist
, it will be ignored. - If
end
is negative, the absolute value of it will be subtracted from the length of thelist
to determine where the range ends. - If
end
is not greater than thebegin
, the range will be empty. compare
is a custom compare to order the list elements. If it is null andlist
items are not Comparable, TypeError is thrown.
Details
The insertion sort algorithm sorts the list
in an increasing order by virtually
splitting it into two parts. Left part is ordered, the right part is unordered.
In each iteration, it removes the first item from unordered part, and insert it
into the ordered part maintaining the increasing order.
Complexity: Time O(n^2)
| Space O(1)
Best Case: Time O(n)
| Space O(1)
Implementation
void insertionSort<E>(
List<E> list, {
int? begin,
int? end,
Comparator<E>? compare,
}) {
int b, e;
int n = list.length;
// Find the range given the parameters.
b = 0;
e = n;
if (begin != null && b < begin) {
b = begin;
}
if (end != null && end < e) {
e = end;
if (e < 0) e += n;
}
if (compare == null) {
insertionSortDefault(list, b, e);
} else {
insertionSortCustom(list, b, e, compare);
}
}