Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Концевой обход двоичного дерева. (How to???)

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
M434F4k3R



Зарегистрирован: 13.05.2002
Сообщения: 2

СообщениеДобавлено: Ср Июн 12 2002 14:26    Заголовок сообщения: Концевой обход двоичного дерева. (How to???) Ответить с цитатой

Пожалуйста, подкиньте нерекурсивную функцию концевого обхода дерева двоичного поиска.
Прямой, обратный обход... С этим всё ясно, а вот концевой...

Дерево задано следующей простенькой структурой:

struct BinTree
{ unsigned Key; // значение ключа
BinTree* Left; // указатель на левого потомка
BinTree* Right; // указатель на правого потомка
}

Единственный параметр функции - указатель на корень дерева.
Скорее всего понадобится стек. Его описание можно не прилагать. Просто пишем push или pop где необходимо.
Функцию желательно на C++ под дос или в крайнем случае BP7. Псевдокод - тоже хорошо.

Заранее благодарен.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Посетить сайт автора
Дядя Вася



Зарегистрирован: 14.08.2002
Сообщения: 39
Откуда: Новосибирск

СообщениеДобавлено: Вт Июн 18 2002 10:20    Заголовок сообщения: Re: Концевой обход двоичного дерева. (How to???) Ответить с цитатой

попробуй не стек использовать, а очередь !
применяя алгоритм обхода дерева в ширину
push(root)
while(очередь не пуста){
node = pop();
if (нету потомков) { че-нить делать}
else{
push(node.left);
push(node.right);
}
}

ну вот и все, если элементы надо иметь по порядку то в {че-нить делать} нужно элемент ложить в массив , вычисляя по положению в дереве, его адрес ...
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...