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

Удаление элемента из сбалансированого бинарного дерева

17.10.2015, 18:45. Показов 2027. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задание: написать программу, которая создает сбалансированное бинарное дерево, написать процедуру, которая удалит все парные элементы дерева.

В общем программа уже написана, проблема только в том, что не удаляются элементы, у которых нет сыновей, т.е. и левый и правый сын пусты. Я так предполагаю, что что-то с рекурсией у меня неправильно. Помогите пожалуйста.

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
#include<iostream>
#include <conio.h>
#include <stdlib.h>
using namespace std;
struct node
{
  int Key;
  int Count;
  node *Left;
  node *Right;
};
 
class TREE
{
  private:
    node *duk;
  public:
    TREE() { duk = NULL; }
    node **GetDuk() { return &duk; }
    node *Tree (int, node **); 
    void Vyvod (node **, int, short int);
    void Delete (node **);
};
 
node *TREE::Tree (int n,node **p)
{
  node *now;
  int x,nl,nr;
        
  now = *p;
  if  (n==0) *p = NULL;
  else
  {
    nl = n/2; 
    nr = n - nl - 1;
    cin>>x;
    now = new(node);
    (*now).Key = x;
    Tree (nl,&((*now).Left));
    Tree (nr,&((*now).Right));
    *p = now;
  }
}
 
 
void TREE::Vyvod (node **w,int l, short int x)
{
  if  (*w!=NULL)
  {
    Vyvod (&((**w).Right),l+1, 0);
    for  (int i=1; i<=l; i++) cout<<"   ";
        if (x==0) cout<<"/";
        if (x==1) cout<<"";
    cout<<(**w).Key<<endl;
    Vyvod (&((**w).Left),l+1, 1);
  }
}
 
void TREE::Delete(node **w){
    
    if (*w!=NULL){
        Delete(&((**w).Right));
        if ((**w).Key%2==0){
            cout<<"----------------"<<(**w).Key<<endl;
            if ((*w)->Right==NULL && (*w)->Left==NULL){ 
                cout<<"-0-"<<endl;  //Вся проблема таится тут, не знаю что здесь написать
            }
                else{
                cout<<"-1-"<<endl;
                node *buf = (*w)->Left;
                node *t = (*w)->Right;
                free(*w);
                *w = t;
                while(*w){
                    w = &(*w)->Left;
                }   
                *w = buf;
            }
        }
        Delete(&((**w).Left));
    }
}
 
 
int main ()
{
  setlocale (LC_ALL, "Russian");
  TREE A;
  int n;
 
  cout<<"Количество элементов дерева - "; cin>>n;
  cout<<"Вводите ключи\n";
  A.Tree (n,A.GetDuk()); 
  A.Vyvod (A.GetDuk(),0, 5);
  for (int i = 0; i<15; i++)     //Тут пускаю циклом, ибо не все с первого раза удаляется. 
    A.Delete(A.GetDuk());
  cout<<"После удаления парных элементов"<<endl;
  A.Vyvod(A.GetDuk(), 0, 5);
  getch();
}
Я напихал в программу кучу cout-ов для себя, чтобы обнаружить проблему. Не ругайтесь, если что)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.10.2015, 18:45
Ответы с готовыми решениями:

удаление элемента бинарного дерева
как удалить элемент бинарного дерева,имеющий 2 потомка?(например дерево (2)-(7 и 0)-(4 и 10),порядок вхождения 2,7,4,10,0 удалить надо...

Удаление элемента из бинарного дерева
Ругается компилятор в Visual Studio при выполнении кода удаления элемента, а именно в том месте, где нужно удалить элемент с двумя...

Некорректное удаление элемента бинарного дерева поиска
Задача состоит в том, чтобы удалить максимальный в левом поддереве элемент и все его порожденные элементы. Я нахожу этот элемент и...

2
0 / 0 / 0
Регистрация: 17.10.2015
Сообщений: 6
18.10.2015, 19:16  [ТС]
Что, ни у кого идей нет?
0
2688 / 2260 / 244
Регистрация: 03.07.2012
Сообщений: 8,231
Записей в блоге: 1
18.10.2015, 20:55
Идея простая - запускаешь отладчик и разбираешься. Делов минут на 10 (максимум).
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.10.2015, 20:55
Помогаю со студенческими работами здесь

Удаление из бинарного дерева
Здравствуйте! Помогите с удалением узла из бинарного дерева. Номер узла вводится пользователем #include &quot;stdafx.h&quot; ...

Удаление элементов из бинарного дерева
Доброго времени суток! Реализую обычное бинарное дерево (НЕ поиска) на базе массива (то еще извращение ._.) Следует написать функцию...

Удаление Узла Бинарного Дерева.
Добрый День.Возникла проблема с реализацией части функции контейнера для удаления элемента с двумя узлами(по всем правилам бинарных...

Удаление бинарного дерева по слоям
вот задачка такая встала и ни че в голову не приходит. как будет выглядеть функция чтоб удаляла бинарное дерево по слоям? плиззз...

Удаление Узла бинарного дерева
Добрый вечер. Имеем Бинарное дерево поиска. При удалении некоторого узла . возникают три случая. Один из случаев , наличие у...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru