Сортировка вставками
Шаблон:Алгоритм Сортировка вставками (Шаблон:Lang-en) — алгоритм сортировки, в котором элементы входной последовательности просматриваются по одному, и каждый новый поступивший элемент размещается в подходящее место среди ранее упорядоченных элементов[1]. Вычислительная сложность — .
Описание

На вход алгоритма подаётся последовательность чисел: . Сортируемые числа также называют ключами. Входная последовательность на практике представляется в виде массива с элементами. На выходе алгоритм должен вернуть перестановку исходной последовательности , чтобы выполнялось следующее соотношение Шаблон:Sfn.
В начальный момент отсортированная последовательность пуста. На каждом шаге алгоритма выбирается один из элементов входных данных и помещается на нужную позицию в уже отсортированной последовательности до тех пор, пока набор входных данных не будет исчерпан. В любой момент времени в отсортированной последовательности элементы удовлетворяют требованиям к выходным данным алгоритмаШаблон:Sfn.
Данный алгоритм можно ускорить при помощи использования бинарного поиска для нахождения места текущему элементу в отсортированной части. Проблема с долгим сдвигом массива вправо решается при помощи смены указателей[2].
Псевдокод
На вход процедуре сортировки подаётся массив , состоящий из элементов последовательности , которые требуется отсортировать. соответствует — размеру исходного массива. Для сортировки не требуется привлечения дополнительной памяти, кроме постоянной величины для одного элемента, так как выполняется перестановка в пределах массива. В результате работы процедуры во входном массиве оказывается требуемая выходная последовательность элементовШаблон:Sfn.
Псевдокод алгоритма:
for j = 2 to A.length do
key = A[j]
i = j-1
while (i > 0 and A[i] > key) do
A[i + 1] = A[i]
i = i - 1
end while
A[i+1] = key
end Шаблон:Sfn
|
for i = 2 to n do
x = A[i]
j = i
while (j > 1 and A[j-1] > x) do
A[j] = A[j-1]
j = j - 1
end while
A[j] = x
end for[3]
|
A[0] = -
for i = 2 to n do
j = i
while (j > 0 and A[j] < A[j - 1]) do
swap (A[j], A[j - 1])
j = j - 1
end while
end for[4]Шаблон:Sfn
|
В последнем варианте обмен x = A[j]; A[j] = A[j-1]; A[j-1] = x представлен операцией swap из-за чего он немного медленнее. Значение введённого А[0] меньше любого значения остальных элементовШаблон:Sfn.
Анализ алгоритма
Время выполнения алгоритма зависит от входных данных: чем большее множество нужно отсортировать, тем большее время потребуется для выполнения сортировки. Также на время выполнения влияет исходная упорядоченность массива. Время работы алгоритма для различных входных данных одинакового размера зависит от элементарных операций, или шагов, которые потребуется выполнитьШаблон:Sfn.
Для каждой инструкции алгоритма введём временную стоимость и количество повторений, где — количество проверок условия во внутреннем цикле whileШаблон:Sfn:
| Код | Стоимость | Повторы |
|---|---|---|
| for j = 2 to A.length | ||
| key = A[j] | ||
| i = j — 1 | ||
| while i > 0 and A[i] > key | ||
| A[i+1] = A[i] | ||
| i = i — 1 | ||
| A[i+1] = key |
Время работы алгоритма сортировки вставками — это сумма времён работы каждого шагаШаблон:Sfn: .
Самым благоприятным случаем является отсортированный массив. При этом все внутренние циклы состоят всего из одной итерации, то есть для всех . Тогда время работы алгоритма составит . Время работы линейно зависит от размера входных данныхШаблон:Sfn.
Анализ наихудшего случая
Наихудшим случаем является массив, отсортированный в порядке, обратном нужному. При этом каждый новый элемент сравнивается со всеми в отсортированной последовательности. Это означает, что все внутренние циклы состоят из j итераций, то есть для всех . Тогда время работы алгоритма составит:
.
Время работы является квадратичной функцией от размера входных данныхШаблон:Sfn.
Анализ среднего случая
Для анализа среднего случая нужно посчитать среднее число сравнений, необходимых для определения положения очередного элемента. При добавлении нового элемента потребуется, как минимум, одно сравнение, даже если этот элемент оказался в правильной позиции. -й добавляемый элемент может занимать одно из положений. Предполагая случайные входные данные, новый элемент равновероятно может оказаться в любой позицииШаблон:Sfn. Среднее число сравнений для вставки -го элементаШаблон:Sfn:
Для оценки среднего времени работы для элементов нужно просуммироватьШаблон:Sfn:
Временная сложность алгоритма — . Однако, из-за константных множителей и членов более низкого порядка алгоритм с более высоким порядком роста может выполняться для небольших входных данных быстрее, чем алгоритм с более низким порядком ростаШаблон:Sfn.
См. также
Примечания
Литература
- Шаблон:Книга:Ахо. Структуры данных и алгоритмы
- Шаблон:Книга:Кнут
- Шаблон:Книга:CLRS
- Шаблон:Книга:Основы современных алгоритмов