Эта статья является кандидатом в добротные статьи

Сортировка вставками

Материал из Википедии — свободной энциклопедии
Перейти к: навигация, поиск
Сортировка вставками
Пример сортировки вставками

Пример сортировки вставками
Предназначение

Алгоритм сортировки

Структура данных

Массив

Худшее время

О(n2) сравнений, обменов

Лучшее время

O(n) сравнений, 0 обменов

Среднее время

О(n2) сравнений, обменов

Затраты памяти

О(n) всего, O(1) вспомогательный

Сортировка вставками (англ. Insertion sort) — алгоритм сортировки, в котором элементы входной последовательности просматриваются по одному, и каждый новый поступивший элемент размещается в подходящее место среди ранее упорядоченных элементов[1]. Вычислительная сложность — .

Описание

Пример сортировки вставками

На вход алгоритма подаётся последовательность чисел: . Сортируемые числа также называют ключами. Входная последовательность на практике представляется в виде массива с элементами. На выходе алгоритм должен вернуть перестановку исходной последовательности , чтобы выполнялось следующее соотношение [2]

В начальный момент отсортированная последовательность пуста. На каждом шаге алгоритма выбирается один из элементов входных данных и помещается на нужную позицию в уже отсортированной последовательности до тех пор, пока набор входных данных не будет исчерпан. В любой момент времени в отсортированной последовательности элементы удовлетворяют требованиям к выходным данным алгоритма[3].

Данный алгоритм можно ускорить при помощи использования бинарного поиска для нахождения места текущему элементу в отсортированной части. Проблема с долгим сдвигом массива вправо решается при помощи смены указателей[4].

Псевдокод

На вход процедуре сортировки подаётся массив , состоящий из элементов последовательности , которые требуется отсортировать.  — размер исходного массива. Для сортировки не требуется привлечения дополнительной памяти, кроме постоянной величины для одного элемента, так как выполняется перестановка в пределах массива. В результате работы процедуры во входном массиве оказывается требуемая выходная последовательность элементов[5]:

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

Анализ алгоритма

Время выполнения алгоритма зависит от входных данных: чем большее множество нужно отсортировать, тем большее время потребуется для выполнения сортировки. Также на время выполнения влияет исходная упорядоченность массива. Время работы алгоритма для различных входных данных одинакового размера зависит от элементарных операций, или шагов, которые потребуется выполнить[6].

Для каждой инструкции алгоритма введём временную стоимость и количество повторений, где  — количество проверок условия во внутреннем цикле while[7]:

Код Стоимость Повторы
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

Время работы алгоритма сортировки вставками — это сумма времён работы каждого шага[8]: .

Самым благоприятным случаем является отсортированный массив. При этом все внутренние циклы состоят всего из одной итерации, то есть для всех . Тогда время работы алгоритма составит . Время работы линейно от размера входных данных[9].

Анализ наихудшего случая

Наихудшим случаем является массив, отсортированный в порядке, обратном нужному. При этом каждый новый элемент сравнивается со всеми в отсортированной последовательности. Это означает, что все внутренние циклы состоят из j итераций, то есть для всех . Тогда время работы алгоритма составит:

.

Время работы является квадратичной функцией от размера входных данных[10].

Анализ среднего случая

Для анализа среднего случая нужно посчитать среднее число сравнений, необходимых для определения положения очередного элемента. При добавлении нового элемента потребуется, как минимум, одно сравнение, даже если этот элемент оказался в правильной позиции. -й добавляемый элемент может занимать одно из положений. Предполагая случайные входные данные, новый элемент равновероятно может оказаться в любой позиции[11]. Среднее число сравнений для вставки -го элемента[12]:

Для оценки среднего времени работы для n элементов нужно просуммировать[13]:

Временная сложность алгоритма — . Однако, из-за константных множителей и членов более низкого порядка алгоритм с более высоким порядком роста может выполняться для небольших входных данных быстрее, чем алгоритм с более низким порядком роста[14].

См. также

Примечания

  1. Кнут Д. Э. 5.2 Внутренняя сортировка // Искусство программирования. Том 3. Сортировка и поиск = The Art of Computer Programming. Volume 3. Sorting and Searching / Под ред. Ю. В. Козаченко. — 2. — М.: Вильямс, 2001. — Т. 3. — 800 с.
  2. CLRS, 2013, p. 38.
  3. CLRS, 2013, p. 39.
  4. Кнут Д. Э. 5.2.1 Сортировка путём вставок // Искусство программирования. Том 3. Сортировка и поиск = The Art of Computer Programming. Volume 3. Sorting and Searching / Под ред. Ю. В. Козаченко. — 2. — М.: Вильямс, 2001. — Т. 3. — 800 с.
  5. CLRS, 2013, p. 39-40.
  6. CLRS, 2013, p. 47.
  7. CLRS, 2013, p. 48.
  8. CLRS, 2013, p. 48-49.
  9. CLRS, 2013, p. 49.
  10. CLRS, 2013, p. 49-50.
  11. Макконнелл, 2004, p. 74.
  12. Макконнелл, 2004, p. 75.
  13. Макконнелл, 2004, p. 75-76.
  14. CLRS, 2013, p. 51.

Литература

  • Ахо А. В., Хопкрофт Д. Э., Ульман Д. Д. Структуры данных и алгоритмы = Data structures and algorithms / Под ред. А. А. Минько. — М.: Вильямс, 2000. — С. 231. — ISBN 5-8459-0122-7.
  • Кнут Д. Э. 5.2.1 Сортировка путём вставок // Искусство программирования. Том 3. Сортировка и поиск = The Art of Computer Programming. Volume 3. Sorting and Searching / Под ред. Ю. В. Козаченко. — 2. — М.: Вильямс, 2001. — Т. 3. — 800 с.
  • Кормен, Т., Лейзерсон, Ч., Ривест, Р., Штайн, К. 2.1. Сортировка вставкой // Алгоритмы: построение и анализ = Introduction to Algorithms / Под ред. И. В. Красикова. — 3-е изд. — М.: Вильямс, 2013. — С. 38-45. — ISBN 5-8459-1794-8.
  • Макконнелл Дж. Основы современных алгоритмов = Analysis of Algorithms: An Active Learning Approach / Под ред. С. К. Ландо. — М.: Техносфера, 2004. — С. 72-76. — ISBN 5-94836-005-9.

Ссылки