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

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

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

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

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

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

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

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

Исходное бинарное дерево превратить в бинарное дерево поиска, при этом сохранив его структуру - C++
Помогите, не могу понять!( Нужно исходное бинарное дерево превратить в бинарное дерево поиска, при этом сохранив его структуру. вот...

Создать бинарное дерево - C++
Ребята, помогите с такое задачей : нужно написать ф-цию для построения бинарного дерево определенным способом, а именно : на входе есть...

Бинарное дерево. Удалить из дерева часть вершин так, чтобы оставшееся дерево стало пирамидой - C++
Дано бинарное дерево. Удалить из дерева часть вершин так, чтобы оставшееся дерево стало пирамидой.

Создать бинарное дерево, по правой ветке - переменные типа инт, по левой - 2 переменные типа чар - C++
Здравствуйте. Необходимо создать бинарное дерево, по правой ветке - переменные типа инт, по левой - 2 переменные типа чар. ругается в...

Бинарное дерево - C++
Объясните пжлст почему не работает программа...при вводе файла пишет -842150451 /*Дан адрес P1 вершины дерева — записи типа TNode, ...

Бинарное дерево - C++
Разработать и реализовать на языке С следующие функции работой с бинарным деревом: 1. Создание пустого дерева 2. Добавление элемента в...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Voivoid
675 / 278 / 12
Регистрация: 31.03.2013
Сообщений: 1,339
16.09.2013, 17:38 #2
Надо же, в коем-то веке более-менее интересная задачка
0
Кудаив
329 / 406 / 24
Регистрация: 27.05.2012
Сообщений: 1,168
Завершенные тесты: 2
16.09.2013, 17:49 #3
почему это g становится сыном f ?
0
fishec
119 / 119 / 30
Регистрация: 07.09.2013
Сообщений: 338
16.09.2013, 17:56  [ТС] #4
Отец соединяется с левым сыном левой связью. Сыновья одного отца соединяются правыми связями
0
zer0mail
2334 / 1960 / 192
Регистрация: 03.07.2012
Сообщений: 7,030
Записей в блоге: 1
16.09.2013, 19:11 #5
Цитата Сообщение от fishec Посмотреть сообщение
Отец соединяется с левым сыном левой связью. Сыновья одного отца соединяются правыми связями
Этого вполне достаточно, чтобы написать программу.
0
fishec
119 / 119 / 30
Регистрация: 07.09.2013
Сообщений: 338
16.09.2013, 19:21  [ТС] #6
Цитата Сообщение от zer0mail Посмотреть сообщение
Этого вполне достаточно, чтобы написать программу.
Можешь примерно в двух словах алгоритм обхода сказать, и какой порядок обхода, и где рекурсивно вызывать функцию? Я просто не могу понять, с чего начать вообще.
0
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], либо добавь в структуру пару дополнительных ссылок, либо параллельно с обходом дерева создавай новую структуры (что более логично) (получится, что бинарное дерево формируется в порядке правый->левый->корень, т.е. в соответствии с обратным обходом дерева)
0
fishec
119 / 119 / 30
Регистрация: 07.09.2013
Сообщений: 338
16.09.2013, 20:08  [ТС] #8
Спасибо, буду разбираться.
Да нужно создать новое дерево отдельно, а не переделывать его. Есть функция "НовыйУзел" с аргументом (указатель на узел исходного дерева), создающая узел типа нового дерева, копирует данные, и возвращает указатель на созданный узел. Куда в этом алгоритме создание вставить?
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.09.2013, 20:08
Привет! Вот еще темы с ответами:

Бинарное дерево - C++
Помогите пожалуйста с программой. Нужно сделать обход, слева и справа(функции get_left и get_right), желательно обход в глубину. И...

Бинарное дерево - C++
Помогите, пожалуйста. Осталась последняя задача в контрольной. Не знаю даже, как к ней подступиться. К проекту ПРИМЕР Btree ...

Бинарное дерево - C++
пытаюсь самостоятельно разобраться с этим, но чето не выходит вот мой листинг. вроде кудато чтото вводит, но ничего не выводит....

Бинарное дерево - C++
Как организовать вывод бинарного дерева?


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
16.09.2013, 20:08
Ответ Создать тему
Опции темы

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