Главная страница Случайная страница КАТЕГОРИИ: АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатикаИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханикаОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторикаСоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансыХимияЧерчениеЭкологияЭкономикаЭлектроника |
Пирамиды (heap - tree)
Пирамида - законченное бинарное дерево, имеющее упорядочение узлов по уровням. Различают максимальные пирамиды и минимальные. В максимальной пирамиде родительский узел больше или равен каждому из своих сыновей. Корень содержит наибольший элемент. В минимальной пирамиде родительский узел меньше или равен каждому из своих сыновей. Корень содержит наименьший элемент.
Пирамида используется в тех приложениях, где клиенту требуется прямой доступ к минимальному элементу. Пирамида является списком, который хранит данные в виде бинарного дерева. Все алгоритмы обработки пирамид сами должны обновлять дерево и поддерживать пирамидальное упорядочение.
Преобразование массива в пирамиду Индекс последнего элемента пирамиды равен n -1. Индекс его родителя равен (n -2)/2, и он определяет последний нелистовой узел пирамиды. Этот индекс является начальным для преобразования массива. Рассмотрим целочисленный массив
Включение элемента в пирамиду
Удаление из пирамиды Данные удаляются всегда из корня дерева.
Пирамидальная сортировка 1. Преобразовать массив в пирамиду. 2. Последовательное исключение A [0] и включение его в A [ n -1], A [ n -2],..., A [1]. (Этот алгоритм основан на том, что после исключения элемента из пирамиды элемент, бывший до этого хвостовым, замещает корневой узел, а его место освобождается. В процессе пирамидальной сортировки очередные наименьшие элементы удаляются и последовательно запоминаются в хвостовой части массива. Таким образом производится сортировка по убыванию. Пример:
Поскольку остался только корень, то массив отсортирован: А = 75, 50, 35, 25, 20. Вычислительная эффективность Массив, содержащий n элементов соответствует законченному бинарному дереву глубиной . Преобразование массива в пирамиду требует n /2 операций, каждая из которых требует не более k сравнений. Вторая фаза сортировки требует выполнения n -1 операции, которая в худшем случае требует k сравнений. Худший случай сложности пирамидальной сортировки . Сложность алгоритма имеет порядок . Пирамидальная сортировка не требует дополнительной памяти (для сравнения: при турнирной сортировке требуется создание дополнительного массива). 3.5. Сбалансированные деревья
|