170 похожих чатов

При реализации метода remove у первой версии бинарного дерево поиска

прога падает. Не знаете, в чем причина?


#include <iostream>
using namespace std;

struct tree_elem
{
int data;
tree_elem *left, *right;
tree_elem(int val = 0)
{
left = nullptr;
right = nullptr;
data = val;
}

void print() const
{
if (left)
left->print();
cout << data << ' ';
if (right)
right->print();
}

void delete_tree()
{
if (this == nullptr)
return;
(this->left)->delete_tree();
(this->right)->delete_tree();
delete this;
}
};

//----------------------------------------------------------->

struct binary_tree
{
int size;
tree_elem * root;
binary_tree(int=0);
~binary_tree();
void add(int);
void remove(int);
void delete_tree();
bool find(int) const;
void print() const;
};

//----------------------------------------------------------->

binary_tree::binary_tree(int first_elem)
{
root = new tree_elem(first_elem);
size = 1;
}

binary_tree::~binary_tree()
{
root->delete_tree();
}

//----------------------------------------------------------->

void binary_tree::add(int new_elem)
{
tree_elem *curr = root;
while (curr->data != new_elem)
{
if (new_elem < curr->data) {
if (curr->left == nullptr) {
curr->left = new tree_elem(new_elem);
size++;
}
curr = curr->left;
}
else if (new_elem > curr->data) {
if (curr->right == nullptr) {
curr->right = new tree_elem(new_elem);
size++;
}
curr = curr->right;
}
}
}

//----------------------------------------------------------->

bool binary_tree::find(int tofind) const
{
tree_elem *curr = root;
while (curr && curr->data != tofind) {
if (tofind < curr->data)
curr = curr->left;
else
curr = curr->right;
}
if (curr)
return true;
return false;
}

//----------------------------------------------------------->

void binary_tree::remove(int toremove)
{
tree_elem *curr = root, *parent;
while (curr && curr->data != toremove) {
parent = curr;

if (toremove < curr->data)
curr = curr->left;
else
curr = curr->right;
}

if (curr == nullptr)
return;
else if (curr->left == nullptr) {
if (parent->left == nullptr)
parent->left = curr->right;
if (parent->right == nullptr)
parent->right = curr->right;
delete curr;
size--;
}
else if (curr->right == nullptr) {
if (parent->left == nullptr)
parent->left = curr->left;
if (parent->right == nullptr)
parent->right = curr->left;
delete curr;
size--;
}
else if (curr->left != nullptr && curr->right != nullptr)
{
tree_elem *curr = parent->right;
tree_elem *removed_element = curr;
curr = curr->left;
while (curr->right)
curr = curr->right;
this->remove(curr->data);
removed_element->data = curr->data;
}
}

//----------------------------------------------------------->

void binary_tree::print() const {root->print();}

//----------------------------------------------------------->

int main()
{
binary_tree tree;
for (int i=0; i<20; ++i)
tree.add(rand() % 20);
tree.print();
cout << endl;
tree.remove(5);
tree.print();
for (int i=0; i<15; ++i)
if (tree.find(i))
cout << i << " - " << "found" << endl;
else
cout << i << " - " << "not found" << endl;
}

4 ответов

20 просмотров

Оберните код в теги: 3 символа ` до и после кода (в случае одиночной конструкции достаточно 1 ` с обеих сторон). Спасибо!

Я знаю....

Ilya Zviagin
Я знаю....

неужели ошибка в коде?))

Till Schneider
неужели ошибка в коде?))

Ну ты такой прозорливый, ужас!

Похожие вопросы

Обсуждают сегодня

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Ребят в СИ можно реализовать ООП?
Николай
33
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
2
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Карта сайта