Заглавная страница Избранные статьи Случайная статья Познавательные статьи Новые добавления Обратная связь КАТЕГОРИИ: АрхеологияБиология Генетика География Информатика История Логика Маркетинг Математика Менеджмент Механика Педагогика Религия Социология Технологии Физика Философия Финансы Химия Экология ТОП 10 на сайте Приготовление дезинфицирующих растворов различной концентрацииТехника нижней прямой подачи мяча. Франко-прусская война (причины и последствия) Организация работы процедурного кабинета Смысловое и механическое запоминание, их место и роль в усвоении знаний Коммуникативные барьеры и пути их преодоления Обработка изделий медицинского назначения многократного применения Образцы текста публицистического стиля Четыре типа изменения баланса Задачи с ответами для Всероссийской олимпиады по праву Мы поможем в написании ваших работ! ЗНАЕТЕ ЛИ ВЫ?
Влияние общества на человека
Приготовление дезинфицирующих растворов различной концентрации Практические работы по географии для 6 класса Организация работы процедурного кабинета Изменения в неживой природе осенью Уборка процедурного кабинета Сольфеджио. Все правила по сольфеджио Балочные системы. Определение реакций опор и моментов защемления |
Поиск по бинарному дереву. Эффективность поиска по бинарному дереву.
Вначале рассмотрим просто поиск по бинарному дереву. Длительность операции зависит от структуры дерева. Действительно, дерево может быть вырождено в однонаправленный список, как правое на рисунке ниже В этом случае время поиска будет такое же, как и в однонаправленном списке, т.е. придется перебирать n/2 элементов. Наибольший эффект использования дерева достигается в том случае, когда дерево сбалансировано. Строго сбалансированное дерево - это дерево, в котором каждый узел имеет левое и правое поддеревья, отличающиеся по уровню не более, чем на единицу. Поиск элемента в сбалансированном дереве называется бинарным поиском по дереву. Такое дерево называют деревом бинарного поиска. При бинарном поиске по дереву перебирается не больше log2N элементов. Другими словами, эффективность бинарного поиска по дереву имеет порядок O(log2N). Суть поиска заключается в следующем. Анализируем вершину очередного поддерева. Если ключ меньше информационного поля вершины, то анализируем левое поддерево, больше - правое.
Алгоритм поиска по бинарному дереву p = tree whlie p <> nil do if key = k(p) then search = p return endif if key < k(p) then p = left(p) else p = right(p) endif endwhile search = nil return Очень часто следствием поиска являются ситуации: если узел с заданным ключом не найден, то его надо вставить;
если узел с заданным ключом найден, то его надо удалить.
Поиск по бинарному дереву с включением. Вначале рассмотрим просто поиск по бинарному дереву. Длительность операции зависит от структуры дерева. Действительно, дерево может быть вырождено в однонаправленный список, как правое на рисунке ниже В этом случае время поиска будет такое же, как и в однонаправленном списке, т.е. придется перебирать n/2 элементов. Наибольший эффект использования дерева достигается в том случае, когда дерево сбалансировано. Строго сбалансированное дерево - это дерево, в котором каждый узел имеет левое и правое поддеревья, отличающиеся по уровню не более, чем на единицу. Поиск элемента в сбалансированном дереве называется бинарным поиском по дереву. Такое дерево называют деревом бинарного поиска. При бинарном поиске по дереву перебирается не больше log2N элементов. Другими словами, эффективность бинарного поиска по дереву имеет порядок O(log2N). Суть поиска заключается в следующем. Анализируем вершину очередного поддерева. Если ключ меньше информационного поля вершины, то анализируем левое поддерево, больше - правое.
|
||||
Последнее изменение этой страницы: 2017-02-05; просмотров: 751; Нарушение авторского права страницы; Мы поможем в написании вашей работы! infopedia.su Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Обратная связь - 3.17.79.60 (0.003 с.) |