С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
Глупец
23 / 23 / 1
Регистрация: 17.05.2011
Сообщений: 141
#1

бинарное дерево - C++

05.11.2011, 05:52. Просмотров 512. Ответов 0
Метки нет (Все метки)

Здравствуйте)
Есть пара вопросов по BST дереву, если кто поможет, скажу спасибо))

для начала, будет ли это L->R->t обходом?))
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
template<typename T>
class stack{
    oeL<T>* head;
    long long size;
public:
inline  long long len();
inline  bool good();
inline  void clear();
inline  void push(T* v);
inline T* pop();
inline T* get();//смотрим НЕ СНИМАЯ элемент головы стэка
stack();
~stack();
};
 
struct print{//вложенная в класс BST структура для итеративного алоритса обхода
        et* p;//указатель на узел дерева
        bool l;//true-прошли влево
        bool r;//true-прошли вправо
 
        print(et* t);// r=l=false; p=t;
    };
 
 
template<typename T>
void bst<T>::step_lrt(){
    stack<bst<T>::print> s;
 
    bst<T>::print* tmp=new bst<T>::print(head);
 
    s.push(tmp);
    bst<T>::et* p;
    bst<T>::print* t;
    while(s.good()){
        t=s.get();
        p=t->p;
        if(!p){delete s.pop();continue;}
        if(!t->l){//кладем левую часть
            t->l=true;
            t=new bst<T>::print(p->l);
            s.push(t);
            continue;
        }
        else if(!t->r){//кладем правую часть
            t->r=true;
            t=new bst<T>::print(p->r);
            s.push(t);
            continue;
        }
        std::cout<<"ключ: "<<p->k<<"\tзначение: "<<p->v<<'\n';
        delete s.pop();
    }
}
и еще очень бы хотелось узнать как сделать
удаление узла с заданным ключом на основе метода объединения двух поддеревьев (рекурсивная форма алгоритма).
как реализовать объединение двух деревьев?)))
в методичке приведен псевдо код, но...он какой-то кривой, ну или я дурак)))

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

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

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

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

Бинарное дерево - C++
Нужно записать в дерево и вывести в форматированном виде каталог файлов(типа windows) на вход даны имена файлов вида c:\win\1 ...

Бинарное дерево - C++
Только начал изучать тему &quot;деревья&quot;. Подскажите в чем ошибка)#include &lt;iostream&gt; using namespace std; struct Node{ int...

бинарное дерево - C++
С помощю бинарного дерева нужна сделать программу,,любую (главное что на экран выводило)

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
05.11.2011, 05:52
Привет! Вот еще темы с ответами:

Бинарное дерево - C++
Подскажите алгоритм распечатки дерева на экран горизонтально, не вертикально, как обычно это делают. struct tree { int k;...

Бинарное дерево - C++
Здравствуйте, Корень создаёться вот так TREE *root=NULL; непонятно почему функия добовления использует указатель на указатель ...

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

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


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

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