Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
fishec
119 / 119 / 30
Регистрация: 07.09.2013
Сообщений: 338
#1

Создать бинарное дерево - C++

16.09.2013, 17:30. Просмотров 672. Ответов 7
Метки нет (Все метки)

Есть обычное дерево.
Узел описывается
struct nod
int Value;
int Number_Of_Sons;
nod *[5]Son

Число сыновей может быть до пяти.

Нужно написать рекурсивную функцию, которая создает из него бинарное дерево и возвращает указатель на корень. Подскажите пожалуйста алгоритм.
Изображения
  
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Voivoid
672 / 275 / 12
Регистрация: 31.03.2013
Сообщений: 1,339
16.09.2013, 17:38     Создать бинарное дерево #2
Надо же, в коем-то веке более-менее интересная задачка
Кудаив
329 / 406 / 24
Регистрация: 27.05.2012
Сообщений: 1,165
Завершенные тесты: 2
16.09.2013, 17:49     Создать бинарное дерево #3
почему это g становится сыном f ?
fishec
119 / 119 / 30
Регистрация: 07.09.2013
Сообщений: 338
16.09.2013, 17:56  [ТС]     Создать бинарное дерево #4
Отец соединяется с левым сыном левой связью. Сыновья одного отца соединяются правыми связями
zer0mail
Нарушитель
2321 / 1947 / 192
Регистрация: 03.07.2012
Сообщений: 6,970
Записей в блоге: 1
16.09.2013, 19:11     Создать бинарное дерево #5
Цитата Сообщение от fishec Посмотреть сообщение
Отец соединяется с левым сыном левой связью. Сыновья одного отца соединяются правыми связями
Этого вполне достаточно, чтобы написать программу.
fishec
119 / 119 / 30
Регистрация: 07.09.2013
Сообщений: 338
16.09.2013, 19:21  [ТС]     Создать бинарное дерево #6
Цитата Сообщение от zer0mail Посмотреть сообщение
Этого вполне достаточно, чтобы написать программу.
Можешь примерно в двух словах алгоритм обхода сказать, и какой порядок обхода, и где рекурсивно вызывать функцию? Я просто не могу понять, с чего начать вообще.
ya_noob
_
201 / 145 / 9
Регистрация: 08.10.2011
Сообщений: 432
16.09.2013, 19:39     Создать бинарное дерево #7
Код
функция(текущий узел):
    если нет узла, возвращаем NULL
    link = 0
    для каждого потомка текущего узла справа налево:
        temp = вызываем рекурсивно для него эту функцию
        правая ссылка очередного потомка = link
        link = temp
    левый потомок текущего узла = link
    возвратить ссылку на текущий узел
как видно из алгоритма (если хорошо приглядеться), функция открепляет всех правых потомков каждого узла внутри цикла а его правым потомком становится его ближайший правый брат (последнее действие происходит на один рекурсивный уровень выше) (этот ближайший брат хранится в переменной link). в конце link будет содержать левого потомка, его мы и сделаем (оставим) левым потомком узла

в цикле temp хранит каждого потомка, для которого выполняется рекурсивный вызов. рекурсивная функция возвращает ту же ссылку, что и была ей передана

кто такие правый и левый потомки реши сам, это может быть Son[0] и Son[1], либо добавь в структуру пару дополнительных ссылок, либо параллельно с обходом дерева создавай новую структуры (что более логично) (получится, что бинарное дерево формируется в порядке правый->левый->корень, т.е. в соответствии с обратным обходом дерева)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.09.2013, 20:08     Создать бинарное дерево
Еще ссылки по теме:

Создать бинарное дерево C++
C++ Бинарное дерево
C++ Бинарное дерево
C++ Бинарное дерево
C++ Бинарное дерево

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
fishec
119 / 119 / 30
Регистрация: 07.09.2013
Сообщений: 338
16.09.2013, 20:08  [ТС]     Создать бинарное дерево #8
Спасибо, буду разбираться.
Да нужно создать новое дерево отдельно, а не переделывать его. Есть функция "НовыйУзел" с аргументом (указатель на узел исходного дерева), создающая узел типа нового дерева, копирует данные, и возвращает указатель на созданный узел. Куда в этом алгоритме создание вставить?
Yandex
Объявления
16.09.2013, 20:08     Создать бинарное дерево
Ответ Создать тему
Опции темы

Текущее время: 20:18. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru