Добавил:
alyonka_stepashka
ПОИТ 2016-2020
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз:
Предмет:
Файл:Пустовалова 2 сем / Лекции / Лекция 6_Деревья.ppt
X
- •Организация данных в виде деревьев
- •Примеры деревьев
- •A,G,M - корни
- •Свойства дерева
- •Дерево
- •Дерево можно определить в виде
- •Логическое представление деревьев
- •►3. Диаграмма Венна
- •Основные операции над деревьями
- •Рекурсивный обход дерева
- •дерева:
- •глубину
- •Применение функций
- •Двоичное, бинарное дерево
- •Бинарное дерево
- •Структура Btree представляет одно звено дерева
- •Функция добавления элемента Insert
- •//Ввод данных с клавиатуры и
- •//Вывод на экран
- •►void main ()
- •Нумерация вершин в деревьях. Способы обхода дерева (traversing)
- •ABCDEFG ( нисходящий ); CBAFEDG ( смешанный ); CBFEGDA ( восходящий ).
- •► struct Node
- •Нисходящий обход
- •Алгоритм
- •Восходящий обход
- •Алгоритм
- •Смешанный обход
- •Алгоритм
- •Основные операции
- •дерева
- •свойства
- •бинарное дерево поиска
- •минимум в поддереве
- •максимум в поддереве
- •следующий по ключу
- •предыдущий по ключу
- •рекурсивный обход поддерева с корнем в узле
- •интерфейс дерево
- •проверка свойства
- •поиск по ключу
- •Вставка
- •удалить по указателю элемента 1. есть ли данные
- •3. Есть правое поддерево у
- •4. У удаляемого только левое поддерево.
- •5.Уудал. есть оба поддерева
- •удалить по ключу
- •вывод при обходе
проверка свойства
поиск по ключу
|
15 |
|
5 |
|
18 |
|
|
|
12 |
16 |
29 |
|
|
Вставка
1.можно ли вставить
2.найти место
3.проверить три случая5
15
18
12 |
16 |
29 |
|
|
удалить по указателю элемента 1. есть ли данные
3. Есть правое поддерево у
удал.
3.1.удал - единственный
3.2.наход. ли в лев подд. Уд
3.3.назначить родителя
4. У удаляемого только левое поддерево.
4.1. есть ли родитель 4.2. наход. ли в лев подд. Уд
4.3.назначить родителя
4.4. удалить
5.Уудал. есть оба поддерева
5.1. получ. след. 5.2. скопировать данн. 5.3. удалить след.
удалить по ключу
вывод при обходе
struct NodeTree
{
char c[20]; int key; };
voidPrint(void* x)
{
cout <<((NodeTree*)x)->key <<ends;
}
NodeTree a1 = {"aaaa", 5}, a2 = {“bbbb", 7};
a3 = {“bbbb", 3};
t1.Insert(&a1); t1.Insert(&a2);t1.Insert(&a3); t1.Root->Min(); t1.Root->Scan(Print);
Node*n;
n=t1.Search(&a2); n = n->Prev();
n =t1.Search(&a2); t1.Delete(n);
Соседние файлы в папке Лекции