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

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

Войти
Регистрация
Восстановить пароль
 
FC_DK
0 / 0 / 0
Регистрация: 18.03.2014
Сообщений: 62
#1

Бинарные деревья: удалить те листья, у которых нет братьев - C++

20.05.2014, 15:40. Просмотров 173. Ответов 0
Метки нет (Все метки)

Помогите написать такую функцию:

Удалить те листья в дереве, у которых нет братьев

Вот обычная функция удаления:
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
TNode* deleteTree(TNode * rootTree,int key){
    TNode * p;
    if(rootTree==NULL){
        return rootTree;
    }
    if(rootTree->inf<key){
        rootTree->right=deleteTree(rootTree->right,key);
        return rootTree;
    }
    else if(rootTree->inf>key){
        rootTree->left=deleteTree(rootTree->left,key);
        return rootTree;
    }
    if(rootTree->inf==key){
        if(rootTree==rootTree->right){
            delete rootTree;
            return NULL;
        }
        else if (rootTree->left==NULL){
            p=rootTree->right;
            delete rootTree;
            return p;
        }
        else if(rootTree->right==NULL){
            p=rootTree->left;
            delete rootTree;
            return p;
        }
        else{
            p=rootTree->right;
            while(p->left){
                p=p->left;
            }
            p->left=rootTree->left;
            p->right=rootTree->right;
            delete rootTree;
            return p;
        }
    }
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.05.2014, 15:40     Бинарные деревья: удалить те листья, у которых нет братьев
Посмотрите здесь:

Деревья. Удалить самые низкие листья (С++) - C++
Написать программу: Дано N-дерево(бинарное). Удалить самый низкий лист(листья). Заранее спасибо!)))

Бинарные деревья - C++
Имею три файла: Скажите пожалуйста почему я не могу создать э-т m?(Класс tree) Он мне пишет - undefined reference to...

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

STL Бинарные деревья с++ - C++
Добрый вечер. Хочу узнать подробно о бинарных деревьях в STL. После поиска по интернету наткнулся на : ...

Бинарные деревья поиска - C++
Здравствуйте. Помогите решить задачу. Написать функцию, которая удаляет из бинарного дерева поиска T вершины с максимальным и минимальным...

Любимые бинарные деревья. - C++
Доброго времени суток. появилась проблема с решением задачи. собсна задача: &quot;найти количество отрицательных узлов в левом и правом...

Задача про Бинарные деревья! - C++
здрасти! помогите плиз с задачей! я вот начал писать и столкнулся с проблемами... вот задание: Записи вершин дерева - вещественные...

Бинарные деревья, очереди, стеки - C++
#include &lt;iostream&gt; // подключение библиотеки ввода-вывода #include &lt;conio.h&gt; // подключение библиотеки функций работы с консолью ...

Бинарные деревья: неправильный вывод - C++
неправильно выводит дерево,что делать? #include&lt;iostream&gt; using namespace std; struct BinarySearchTree { int data; ...

Бинарные деревья и поиск по ним - C++
Необходимо создать программу для дисциплины ИИ Задача - в поле 4х4 есть игрок и 3 блока (А,Б и С). Начальное состояние задается руками в...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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