Древовидная организация данных

Древовидной организацией данных (деревом) называется множество записей, расположенных по уровням следующим образом:

- на 1-м уровне расположена только одна запись (корень дерева),

- к любой записи i-го уровня ведет адрес связи только от одной записи уровня i-1.

Количество уровней в дереве называется рангом. Записи дерева, которые адресуются от общей записи (i-l)-ro уровня, образуют группу. Максимальное число элементов в группе называется порядком дерева. Деревья обычно формируются двунаправленными, адрес связи от записи уровня i+1 к записи i-го уровня называется обратным.

При размещении дерева в памяти ЭВМ каждая запись мо­жет занимать произвольное место.

Рассмотрим деревья порядка 2 (бинарные). Они интерес­ны тем, что составляющие их записи могут быть упорядоче­ны. Для этого один из атрибутов записи должен быть объяв­лен ключевым.

Запись А - корень дерева. Записи, у которых заполнены два адреса связи, называются полными, записи с одним заполненным адресом - неполными, записи с двумя незаполненными адресами - концевыми. На рис. 7 записи А, В, Е, F - полные, С - неполная, D, H, I, J, G -концевые. Адреса связи делятся на левые и правые. Так, адрес от Е к G -левый, от Е к Н - правый. Каждая запись имеет левую и правую ветви. Правую (левую) ветвь записи образует подде­рево, адресованное из этой записи через правый (левый) адрес связи. У записи С правая ветвь состоит из записей F, I, J, ле­вая ветвь пустая.

В упорядоченном бинарном дереве значение ключевого атри­бута каждой записи должно быть больше, чем значение ключа у любой записи на ее левой ветви, и не меньше, чем ключ любой записи на ее правой ветви. Это определение позволяет также различать левые и правые адреса (ветви).

 

Рисунок 3.5. Пример бинарного дерева

а)Упорядоченное бинарное дерево формируется из неупоря­доченного массива записей по специальному алгоритму. Этот алгоритм создает дерево из первой записи массива, затем -дерево из первых двух записей, из первых трех записей и так далее до исчерпания всех записей массива.

Алгоритм формирования упорядоченного бинарного дерева:

1) Первая запись массива с ключом р(1) становится корнем дерева.

2) Значение ключа второй записи р(2) сравнивается с р(1), находящимся в корне дерева. Если р(2)<р(1), то вторая запись помещается на левой от корня ветви, в противном случае - на правой ветви. Сейчас получено упорядоченное дерево из пер­вых двух записей, далее на каждом шаге создается упорядо­ченное дерево из первых i записей.

3) Для i-й записи массива ключ p(i) сравнивается с корневым значением, и выполняется переход по левому адресу если p(l)>p(i)), а при p(l)<=p(i) - по правому адресу. Ключ достигнутой записи так­же сравнивается с p(i), и снова организуется переход по лево­му или правому адресу и т. д. Когда будет достигнут незапол­ненный адрес связи, то он должен адресовать запись с ключом p(i). Указанные действия повторяются до исчерпания всех за­писей исходного массива.

б) В процессе поискаданных по совпадению в упорядочен­ном бинарном дереве просматривается некоторый путь по де­реву, начинающийся всегда в его корне. Искомое значение ключа q сравнивается со значением корня р(1). Если p(l)>q, просмотр дерева продолжается по левой ветви корня, если p(l)<=q - по правой.

Поиск заканчивается, когда у какой-либо записи отсутству­ет адрес связи, необходимый для дальнейшего продолжения поиска. Количество сравнений С пропорционально logM

в) Включение новой записи при корректировке упорядоченно­го бинарного дерева означает выполнение одного шага алго­ритма формирования дерева с включаемой записью на входе.

Сложность исключения зависит от того, какая запись ис­ключается - концевая, неполная или полная. Первые два слу­чая аналогичны корректировке при списковой организации данных. Адрес связи на исключаемую концевую запись заме­няется на признак конца строки, адрес связи на исключаемую неполную запись заменяется на ее собственный адрес связи.

При исключении полной записи решается задача о подста­новке на ее место другой записи, такой, что ее ключ не нару­шает общей упорядоченности бинарного дерева - такие запи­си называются соседними. Соседняя слева запись - это запись с ключом, который непосредственно меньше ключа данной за­писи, а ключ соседней справа записи равен или непосредствен­но больше, чем ключ данной записи.

 








Дата добавления: 2015-03-09; просмотров: 864;


Поиск по сайту:

При помощи поиска вы сможете найти нужную вам информацию.

Поделитесь с друзьями:

Если вам перенёс пользу информационный материал, или помог в учебе – поделитесь этим сайтом с друзьями и знакомыми.
helpiks.org - Хелпикс.Орг - 2014-2024 год. Материал сайта представляется для ознакомительного и учебного использования. | Поддержка
Генерация страницы за: 0.006 сек.