![]() |
Модераторы: Partizan, gambit |
![]() ![]() ![]() |
|
RiG1 |
|
||||
Новичок Профиль Группа: Участник Сообщений: 9 Регистрация: 4.12.2011 Репутация: нет Всего: нет |
Неодходимо реализовать программу, создающую AVL дерево. Функции добавления узлов и поиск по дереву. Т.к. понятних для меня исходников не нашел, решил писать сам.
Вот текущий код
Как я понял из алгоритма добавления вершины
после добавления вершины методом Add необходимо проверить балансировку дерева и отбалансировать его(Чтобы это было именно AVL дерево) Тут то и возникла проблема. Я не имею представления как это сделать. И ещё хотелось бы как можно графически вывести дерево на экран в консоли. Прошу помощи у вас. |
||||
|
|||||
Экскалупатор |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1746 Регистрация: 1.4.2009 Где: г. Минск Репутация: 11 Всего: 24 |
в википедии про балансировку расписано довольно подробно, методы "вращения", даже картинки нарисованы из какого состояния к какому нужно привести. с чем именно проблема?
по поводу вывода: проще всего, на мой взгляд, выводить в консоль дерево что бы его вершина была слева. для этого нужно опуститься в одну из ветвей до конца, при этом подсчитать сколько уровней пришлось пройти, и перед выводом добавить в строку количество отступов равное уровню узла. и повторять эту операцию пока не выведешь все дерево. должно получится как то так: 101 100 90 75 60 50(вершина) 36 30 5 4 |
|||
|
||||
RiG1 |
|
|||
Новичок Профиль Группа: Участник Сообщений: 9 Регистрация: 4.12.2011 Репутация: нет Всего: нет |
Про вращение я кое что понял, но я не могу даже представить как это реализовать в коде...
|
|||
|
||||
RiG1 |
|
|||
Новичок Профиль Группа: Участник Сообщений: 9 Регистрация: 4.12.2011 Репутация: нет Всего: нет |
в Данный момент написал такие классы
Имеется метод Add Помогите дописать поиск по дереву и вывод его на экран |
|||
|
||||
![]() ![]() ![]() |
Прежде чем создать тему, посмотрите сюда: | |
|
Используйте теги [code=csharp][/code] для подсветки кода. Используйтe чекбокс "транслит" если у Вас нет русских шрифтов. Что делать если Вам помогли, но отблагодарить помощника плюсом в репутацию Вы не можете(не хватает сообщений)? Пишите сюда, или отправляйте репорт. Поставим :) Так же не забывайте отмечать свой вопрос решенным, если он таковым является :) Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, mr.DUDA, THandle. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Общие вопросы по .NET и C# | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |