Изменения

Перейти к: навигация, поиск

Сортировка слиянием

3 байта добавлено, 15:55, 5 июня 2015
м
Нет описания правки
==Принцип работы==
[[Файл:Merging_two_arrays.png|270px|right|thumb|Пример работы процедуры слияния.]]
 
[[Файл:Merge sort1.png|300px|right|thumb|Пример работы рекурсивного алгоритма сортировки слиянием]]
 
[[Файл:Merge sort itearative.png|300px|right|thumb|Пример работы итеративного алгоритма сортировки слиянием]]
 
Алгоритм использует принцип «разделяй и властвуй»: задача разбивается на подзадачи меньшего размера, которые решаются по отдельности, после чего их решения комбинируются для получения решения исходной задачи. Конкретно процедуру сортировки слиянием можно описать следующим образом:
===Рекурсивный алгоритм===
[[Файл:Merge sort1.png|300px|right|thumb|Пример работы рекурсивного алгоритма сортировки слиянием]]
Функция сортирует подотрезок массива с индексами в полуинтервале <tex>[left; right)</tex>.
<code style="display: inline-block">
===Итеративный алгоритм===
[[Файл:Merge sort itearative.png|300px|right|thumb|Пример работы итеративного алгоритма сортировки слиянием]]
При итеративном алгоритме используется на <tex>O(\log n)</tex> меньше памяти, которая раньше тратилась на рекурсивные вызовы.
<code style="display: inline-block">

Навигация