Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.87/132: Рейтинг темы: голосов - 132, средняя оценка - 4.87
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 7

Реализация бинарного дерева поиска

06.08.2013, 21:40. Показов 25343. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задача: Реализация бинарного дерева поиска
Компилируется нормально, а при запуске выбивает ошибку : "Необработанное исключение по адресу 0x00C83867 в FindBinaryTree.exe: 0xC0000005: нарушение прав доступа при чтении по адресу 0xCDCDCDCD."
Помогите пожалуйста, занялся изучением алгоритмов и структур данных просто
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
#include <iostream>
 
using namespace std;
 
struct Node
{
    int data;
    Node *parent, *left, *right;
};
 
typedef Node *PNode;
 
class FBTree
{
private:
    PNode Head;
public:
    FBTree() : Head(NULL)
    {
 
    }
    void InsertNode(int n)
    {
        PNode z = new Node;
        PNode y = NULL;
        PNode x = Head;
 
        z->data = n;
 
        while(x != NULL)
        {
            y = x;
            if((z->data) < (x->data))
                x = x->left;
            else
                x = x->right;
        }
        z->parent = y;
        if(y == NULL)
            Head = z;
        else
        {
            if((z->data)<(y->data))
                y->left = z;
            else
                y->right = z;
        }
        z->left = NULL;
        z->right = NULL;
 
        delete x;
        delete y;
    }
    FBTree(int n)
    {
        InsertNode(n);
    }
    //Итеративный поиск
    PNode FindNode(int n)
    {
        PNode x = Head;
 
        while((x != NULL)&&(x->data != n))
            if(n < (x->data))
                x = x->left;
            else
                x = x->right;
        return x;
    }
    PNode GetHead()
    {
        return Head;
    }
    PNode TreeMin(PNode x)
    {
        while((x->left) != NULL)
            x = x->left;
        return x;
    }
    PNode TreeMax(PNode x)
    {
        while((x->right) != NULL)
            x = x->right;
        return x;
    }
    void SymmetricShow(PNode x)
    {
        if(x == NULL)
            return;
        SymmetricShow(x->left);
        cout << (x->data);
        SymmetricShow(x->right);
    }
    void DeleteNode(int n)
    {
        PNode pointer = Head;
        PNode parent  = NULL;
 
        while((pointer != NULL) && (pointer->data != n))
        {
            parent = pointer;
            if(n < (pointer->data))
                pointer = pointer->left;
            else
                pointer = pointer->right;
        }
 
        if(pointer != NULL)
        {
            PNode removed = NULL;
 
            if ((pointer->left == NULL) || (pointer->right == NULL))
            {   
                PNode child = NULL;
                removed = pointer;
 
                if((pointer->left) != NULL)
                    child = pointer->left;
                else 
                    if((pointer->right) != NULL)
                        child = pointer->right;
 
                if(parent == NULL)
                    Head = child;
                else
                {
                    if((parent->left) == pointer)
                        parent->left = child;
                    else
                        parent->right = child;
                }
            }
            else // (pointer->left != NULL && pointer->right != NULL)
            {
                PNode mostLeft = pointer->right;
                PNode mostLeftParent = pointer;
            
                while ((mostLeft->left) != NULL)
                {
                    mostLeftParent = mostLeft;
                    mostLeft = mostLeft->left;
                }
 
                pointer->data = mostLeft->data;
                removed = mostLeft;
 
                if((mostLeftParent->left) == mostLeft)
                    mostLeftParent->left = NULL;
                else
                    mostLeftParent->right = mostLeft->right;
            }
            delete removed;
        }
    }
    void DeleteTree(PNode x)
    {
        if(x == NULL)
            return;
        DeleteTree(x->left);
        DeleteNode(x->data);
        DeleteTree(x->right);
    }
};
 
int main()
{
    setlocale(LC_ALL, "rus");
    FBTree f;
 
    f.InsertNode(1);
    f.InsertNode(2);
    f.InsertNode(3);
    f.InsertNode(4);
    f.InsertNode(5);
    f.InsertNode(6);
    cout << "Двоичное дерево:" << endl;
    f.SymmetricShow(f.GetHead());
    cout << endl << "Максимальный элемент дерева = " << (f.TreeMax(f.GetHead()))->data << ", минимальный элемент дерева = " << (f.TreeMin(f.GetHead()))->data << ";" << endl << endl;
    int n;
    cout << "Введите элемент, который хотите найти: ";
    cin >> n;
    if(f.FindNode(n) != NULL)
        cout << endl << "Этот элемент есть в дереве!" << endl << endl;
    else
        cout << endl << "Этот элемент отсутствует в дереве!" << endl << endl;
    
    f.DeleteTree(f.GetHead());
    system("pause");
}
Заранее спасибо!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.08.2013, 21:40
Ответы с готовыми решениями:

Реализация бинарного дерева поиска
Не выводит значения узлов деревьев, как я понял происходит утечка памяти, но я не пойму, что нужно сделать. Программа ошибку не выдаёт....

Реализация бинарного дерева
Доброго времени суток, уважаемые форумчане. Возник вопрос по реализации бинарного дерева на С++, а именно с методом удаления элемента в...

Реализация бинарного дерева
написать программу, реализующую бинарное дерево. Предусмотреть процедуры и функции: инициализация дерева, вставка элемента (вершины),...

3
545 / 344 / 12
Регистрация: 05.11.2010
Сообщений: 1,076
Записей в блоге: 1
06.08.2013, 22:49
https://www.dropbox.com/s/wsol... archTree.h
Вот тебе несбалансированное и неидеальное, но дерево поиска )
0
 Аватар для RealMogAika
2 / 2 / 1
Регистрация: 02.05.2013
Сообщений: 8
07.08.2013, 00:13
Я тебе могу сказать, что ошибка происходит здесь:
C++
1
 f.InsertNode(4);
Сейчас разберу получше.

Ннда. Суть в том, что в этом месте функции InsertNode значения x и y указывают в никуда.
C++ (Qt)
1
2
3
4
5
6
7
8
while(x != NULL)
{
    y = x;
    if((z->data) < (x->data))
        x = x->left;
    else
        x = x->right;
}
1
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 7
07.08.2013, 12:06  [ТС]
Спасибо, я уже сам нашел её... Надо было удалить строки 52 и 53, а то я удалял ие узлы, которые создавал.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.08.2013, 12:06
Помогаю со студенческими работами здесь

Реализация и вывод бинарного дерева
Помогите создать бинарное дерево и вывести его на экран по уровням. Заранее спасибо.

Реализация бинарного дерева классом
Добрый вечер. Написал класс class TreeClass { int number; TreeClass *left, *right; public: void AddNode(int, TreeClass); ...

Распечатка бинарного дерева поиска
Много где висит функция void print(int deep, ptree p) { if(p) { print(deep + 1, p-&gt;l); for ( int i = 0; i &lt; deep; i...

Алгоритм бинарного дерева поиска
Здравствуйте! Помогите найти информацию по поводу данного алгоритма, может быть какие-то книги/сайты и тп. При поиске находит алгоритм...

Итератор дерева бинарного поиска
Если у нас в качестве коллекции выступают вектора, очереди, стеки и т.п. то там вроде бы всё понятно инкремент, декремент итератора...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru