- Главная
- Информатика
- Рекурсивные алгоритмы для деревьев (иллюстрации)

Содержание
Слайд 2class TreeNode { //Узел дерева
…
//Вывод списка объектов с сортировкой по ключам
public
class TreeNode { //Узел дерева
…
//Вывод списка объектов с сортировкой по ключам
public

void viewLeftRight (){
//Используется процедура обхода (просмотра) двоичного
// дерева слева направо (рекурсивный алгоритм)
//this — указатель на корень дерева (поддерева);
//обойти левое поддерево
if (left != null)
left.viewLeftRight();
//вывести информацию корневого узла дерева (поддерева)
System.out.println(inf);
//обойти правое поддерево
if (right != null)
right.viewLeftRight();
}
/*Вывод (обработка корневого узла) осуществляется только
после возврата из метода viewLeftRight(), запущенного для
левого поддерева - left.viewLeftRight(); - обработка 2-1-3*/
//Используется процедура обхода (просмотра) двоичного
// дерева слева направо (рекурсивный алгоритм)
//this — указатель на корень дерева (поддерева);
//обойти левое поддерево
if (left != null)
left.viewLeftRight();
//вывести информацию корневого узла дерева (поддерева)
System.out.println(inf);
//обойти правое поддерево
if (right != null)
right.viewLeftRight();
}
/*Вывод (обработка корневого узла) осуществляется только
после возврата из метода viewLeftRight(), запущенного для
левого поддерева - left.viewLeftRight(); - обработка 2-1-3*/
Слайд 3null
null
1
3
4
5
6
7
8
10
13
14
null
Терминал:
null
null
null
null
null
null
null
null
Обработка корня дерева (поддерева) - вывод данных узла
null
null
1
3
4
5
6
7
8
10
13
14
null
Терминал:
null
null
null
null
null
null
null
null
Обработка корня дерева (поддерева) - вывод данных узла

Слайд 4…
//Подсчет количества вершин на уровне level
public int nodeCount (int level){
//this
…
//Подсчет количества вершин на уровне level
public int nodeCount (int level){
//this

— указатель на корень дерева (поддерева);
if (level == 1) return 1;
return ((left != null) ? left.nodeCount(level-1) : 0) +
((right != null) ? right.nodeCount(level-1) : 0);
}
} //TreeNode
if (level == 1) return 1;
return ((left != null) ? left.nodeCount(level-1) : 0) +
((right != null) ? right.nodeCount(level-1) : 0);
}
} //TreeNode
/* При каждом рекурсивном вызове параметр level метода nodeCount() уменьшается на 1.
Если при очередном вызове метода nodeCount() параметр level еще не равен 1, а указатель на левое (правое) поддерево уже равен null, значит узла в соответствующем поддереве на изначально заданном уровне нет (возврат нуля). Если удалось дойти до значения level равно 1, то узел есть (возврат единицы)*/
- Предыдущая
през Л2Следующая -
Изготовление обувной полки
Интернет. Территория безопасности
Операционные системы, среды и оболочки
Информация. Измерение информации
Презентация на тему Возможности использования компьютерной техники
Семисегментный индикатор
Измерение информации
Написание тест-кейсов
День отказа от интернета
Программные средства реализации информационных процессов
Как устроен бэкенд Модульбанка
Программирование на языке Паскаль. Оператор выбора
Работа над ошибками. Урок информатики
Комментарии к сайту Вишиванки для детей и взрослых
Приложение My Time
Моделирование состояния биметаллических конструкций
Стикеры в Paint Tool Sai. Мастер-класс Новогоднее настроение
Молодежная медиасфера
CSS (каскадные документы стилей)
Понятие компьютерной сети. Классификация компьютерных сетей. Топология компьютерных сетей
Компьютерные сети, IP, DNS, утилиты командной строки, брандмауэр
Герои меча и магии
Доработка игры
ВКР: Розробка засобу навчання для підготовки оператора комп’ютерної верстки
Практическая работа. Файлы и файловая структура
Программирование на языке Паскаль
Преимущества библиотеки передового опыта
Сценарно-режиссерский ход (прием)
Представление данных. Принципы кодирования информации. Раздел 2