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

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

Восстановить пароль Регистрация
 
fishec
 Аватар для fishec
118 / 118 / 30
Регистрация: 07.09.2013
Сообщений: 337
16.09.2013, 17:30     Создать бинарное дерево #1
Есть обычное дерево.
Узел описывается
struct nod
int Value;
int Number_Of_Sons;
nod *[5]Son

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

Нужно написать рекурсивную функцию, которая создает из него бинарное дерево и возвращает указатель на корень. Подскажите пожалуйста алгоритм.
Изображения
  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.09.2013, 17:30     Создать бинарное дерево
Посмотрите здесь:

C++ бинарное дерево
C++ Бинарное дерево
Бинарное дерево C++
C++ Бинарное дерево
C++ бинарное дерево
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Voivoid
 Аватар для Voivoid
580 / 256 / 12
Регистрация: 31.03.2013
Сообщений: 1,283
16.09.2013, 17:38     Создать бинарное дерево #2
Надо же, в коем-то веке более-менее интересная задачка
Кудаив
328 / 405 / 24
Регистрация: 27.05.2012
Сообщений: 1,162
Завершенные тесты: 2
16.09.2013, 17:49     Создать бинарное дерево #3
почему это g становится сыном f ?
fishec
 Аватар для fishec
118 / 118 / 30
Регистрация: 07.09.2013
Сообщений: 337
16.09.2013, 17:56  [ТС]     Создать бинарное дерево #4
Отец соединяется с левым сыном левой связью. Сыновья одного отца соединяются правыми связями
zer0mail
2183 / 1866 / 187
Регистрация: 03.07.2012
Сообщений: 6,633
Записей в блоге: 1
16.09.2013, 19:11     Создать бинарное дерево #5
Цитата Сообщение от fishec Посмотреть сообщение
Отец соединяется с левым сыном левой связью. Сыновья одного отца соединяются правыми связями
Этого вполне достаточно, чтобы написать программу.
fishec
 Аватар для fishec
118 / 118 / 30
Регистрация: 07.09.2013
Сообщений: 337
16.09.2013, 19:21  [ТС]     Создать бинарное дерево #6
Цитата Сообщение от zer0mail Посмотреть сообщение
Этого вполне достаточно, чтобы написать программу.
Можешь примерно в двух словах алгоритм обхода сказать, и какой порядок обхода, и где рекурсивно вызывать функцию? Я просто не могу понять, с чего начать вообще.
ya_noob
_
200 / 144 / 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++

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

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

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