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

Почему удаляются только те чётные элементы которые я добавил, а не все которые есть в бинарном дереве?

29.10.2020, 10:40. Показов 2548. Ответов 23

Студворк — интернет-сервис помощи студентам
Почему удаляются только те чётные элементы которые я добавил, а не все которые есть в бинарном дереве?
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
190
191
192
193
194
195
196
197
198
#include<iostream>
#include<cstdlib>
 
using namespace std;
 
int tabs = 0;
 
struct Node
{
    int Data;
    Node* Left;
    Node* Right;
};
 
void Add(int aData, Node*& aNode)
{
    if(!aNode)
    {
        aNode = new Node;
        aNode->Data = aData;
        aNode->Left = 0;
        aNode->Right = 0;
        return;
    }
    else
    {
        if(aNode->Data > aData)
        {
            Add(aData, aNode->Left);
        }
        else
        {
            Add(aData, aNode->Right);
        }
    }
}
 
void print(Node* aNode)
{
    if(!aNode) return;
    tabs+= 5;
    print(aNode->Left);
    for(int i = 0; i < tabs; i++) cout <<" ";
    {
        cout <<aNode->Data<<endl;
    }
    print(aNode->Right);
    tabs-= 5;
    return;
}
 
void pr_obh(Node*& aNode)
{
    if(aNode == NULL) return;
    pr_obh(aNode->Left);
    cout<<aNode->Data<<endl;
    pr_obh(aNode->Right);
}
 
void obr_obh(Node*& aNode)
{
    if(aNode == NULL) return;
    obr_obh(aNode->Right);
    cout <<aNode->Data<<endl;
    obr_obh(aNode->Left);
}
 
void add_elem(int aData, Node*& aNode)
{
    if(!aNode)
    {
        aNode = new Node;
        aNode->Data = aData;
        aNode->Left = 0;
        aNode->Right = 0;
        return;
    }
    else
    {
        if(aData < aNode->Data)
        {
            add_elem(aData, aNode->Left);
        }
        else if(aData > aNode->Data)
        {
            add_elem(aData, aNode->Right);
        }
    }
}
 
Node* delete_elem(int aData, Node*& aNode)
{
    if(aNode == NULL)
        return aNode;
        
    if(aNode->Data == aData)
    {
        Node* temp;
        if(aNode->Right == NULL)
        {
            temp = aNode->Left;
        }
        else
        {
            Node* temp2 = aNode->Right;
            
            if(aNode->Left == NULL)
            {
                temp2->Left = aNode->Left;
                temp = temp2;
            }
            else
            {
                Node* temp3 = temp2->Left;
                while(temp3->Left != NULL)
                {
                    temp2 = temp3;
                    temp3 = temp2->Left;
                }
                temp2->Left = temp3->Right;
                temp3->Left = aNode->Left;
                temp3->Right = aNode->Right;
            }
        }
        delete aNode;
        return temp;
    }
    else if(aData < aNode->Data)
    {
        aNode->Left = delete_elem(aData, aNode->Left);
    }
    else
    {
        aNode->Right = delete_elem(aData, aNode->Right);
    }
    return aNode;
}
 
void Delete_tree(Node*& aNode)
{
    if(!aNode) return;
    Delete_tree(aNode->Left);
    Delete_tree(aNode->Right);
    delete aNode;
    return;
}
 
int main()
{
    Node* Root = 0;
    int N;
    int element;
    setlocale(0, "rus");
    cout <<"Введите количество элементов будующего дерева: ";
    cin >> N;
    for(int i = 0; i < N; i++)
    {
        Add(rand() % 100, Root);
    }
    cout <<"Вывод дерева: "<<endl;
    print(Root);
    cout << endl;
    
    cout <<"Прямой обход: "<<endl;
    pr_obh(Root);
    cout << endl;
    
    cout <<"Обратный обход: "<<endl;
    obr_obh(Root);
    cout << endl;
    
    cout <<"Добавление нового элемента"<<endl;
    cout <<"Введите элемент: ";
    cin >> element;
    add_elem(element, Root);
    
    cout <<"Вывод дерева: "<<endl;
    print(Root);
    cout << endl;
    
    cout <<"Удаление чётных элементов"<<endl;
    for(int i = 0; i < N; i++)
    {
        if (element % 2 == 0)
        {
            delete_elem(element, Root);
        }
    }
    
    cout <<"Вывод дерева: "<<endl;
    print(Root);
    cout << endl;
    
    Delete_tree(Root);
    cout <<"Вся динамическая память очищена";
    
    return 0;
}
Что не так?
Миниатюры
Почему удаляются только те чётные элементы которые я добавил, а не все которые есть в бинарном дереве?  
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.10.2020, 10:40
Ответы с готовыми решениями:

Почему удаляются не все строки, которые соответствуют условию?
Мне нужно удалить записи за неделю У меня есть такой запрос: DELETE FROM kassa WHERE date_system &gt;= DATEADD(day, -7,...

Элементы которые имеют четный индексы упорядочить по возростанию а элементы которые не четные по убыванию
3)Элементы которые имеют четный индексы упорядочить по возростанию а элементы которые не четные по убыванию 4)Вывести в порядке убывания...

Если в дереве есть хотя бы один простой элемент, то найти сумму не листьев; иначе увеличить все четные элементы вдвое
Дано дерево целых чисел. Если в дереве хотя бы один простой элемент, то найти сумму не листьев. Иначе увеличить все четные элементы вдвое. ...

23
2 / 2 / 0
Регистрация: 23.08.2020
Сообщений: 167
02.11.2020, 15:40  [ТС]
Студворк — интернет-сервис помощи студентам
igorrr37, Здравствуйте, в выше представленном коде удаление чётных элементов было реализовано рекурсивно.
Можно ли удалить чётные элементы не рекурсивно в ниже представленном коде?
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
Node* Del_Info(Node*& aNode, int aData)
{
    Node *Del, *Prev_Del, *R, *Prev_R;
    Del = aNode;
    Prev_Del = NULL;
    
    while(Del != NULL && Del -> Data != aData)
    {
        Prev_Del = Del;
        if(Del->Data > aData)
        {
            Del = Del->Left;
        }
        else
        {
            Del = Del->Right;
        }
    }
    if(Del == NULL)
    {
        cout <<"Элемент не найден" << endl;
        return aNode;
    }
    
    if(Del -> Right == NULL)
    {
        R = Del->Left;
    }
    
    else
    {
        if(Del -> Left == NULL)
        {
            R = Del->Right;
        }
        else
        {
            Prev_R = Del;
            R = Del->Left;
            while (R->Right != NULL)
            {
                Prev_R = R;
                R = R->Right;
            }
            
            if(Prev_R == Del)
            {
                R->Right = Del->Right;
            }
            else
            {
                R->Right = Del->Right;
                Prev_R->Right = R->Left;
                R->Left = Prev_R;
            }
        }
        if(Del == aNode)
        {
            aNode = R;
        }
        else
        {
            if(Del->Data < Prev_Del->Data)
            {
                Prev_Del->Left = R;
            }
            else
            {
                Prev_Del->Right = R;
                delete Del;
                return aNode;
            }
        }
    }
}
0
 Аватар для igorrr37
2897 / 2044 / 992
Регистрация: 21.12.2010
Сообщений: 3,793
Записей в блоге: 9
02.11.2020, 18:56
Цитата Сообщение от Egorka2000 Посмотреть сообщение
Можно ли удалить чётные элементы не рекурсивно
можно через стек
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
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
#include <iostream>
#include <cstdlib>
#include <algorithm>
#include <ctime>
#include <stack>
 
using namespace std;
 
int tabs = 0;
struct Node;
Node* Root = 0;
 
struct Node
{
    int Data{};
    Node* Left{};
    Node* Right{};
};
 
Node* Add(int aData, Node*& aNode)
{
    Node* pRet = 0;
    if (!aNode)
    {
        aNode = new Node;
        aNode->Data = aData;
        aNode->Left = 0;
        aNode->Right = 0;
        pRet = aNode;
        return pRet;
    }
    else
    {
        if (aNode->Data > aData)
        {
            pRet = Add(aData, aNode->Left);
        }
        else
        {
            pRet = Add(aData, aNode->Right);
        }
    }
    return pRet;
}
 
void print(Node* aNode)
{
    if (!aNode) return;
    tabs += 5;
    print(aNode->Left);
    for (int i = 0; i < tabs; i++)
    {
        cout << " ";
    }
    cout << aNode->Data << endl;
    print(aNode->Right);
    tabs -= 5;
    return;
}
 
void pr_obh(Node* aNode)
{
    std::stack<Node*> stk;
    stk.push(aNode);
    while (true)
    {
        while (true)
        {
            Node* pTop = stk.top();
            if (!pTop)
            {
                stk.pop();
                break;
            }
            if (pTop->Left)
            {
                stk.push(pTop->Left);
            }
            else
            {
                break;
            }
        }
        if (stk.empty())
        {
            break;
        }
        Node* pTop = stk.top();
        stk.pop();
        if (!pTop)
        {
            break;
        }
        std::cout << pTop->Data << std::endl;
        stk.push(pTop->Right);
    }
}
 
Node* findEven(Node* aNode)
{
    Node* pRet = 0;
    std::stack<Node*> stk;
    stk.push(aNode);
    while (true)
    {
        while (true)
        {
            Node* pTop = stk.top();
            if (!pTop)
            {
                stk.pop();
                break;
            }
            if (pTop->Left)
            {
                stk.push(pTop->Left);
            }
            else
            {
                break;
            }
        }
        if (stk.empty())
        {
            break;
        }
        Node* pTop = stk.top();
        stk.pop();
        if (!pTop)
        {
            break;
        }
        if (pTop->Data % 2 == 0)
        {
            pRet = pTop;
            break;
        }
        stk.push(pTop->Right);
    }
    return pRet;
}
 
Node* findParent(Node* aNode, Node* pChild)
{
    Node* pRet = 0;
    if (pChild)
    {
        std::stack<Node*> stk;
        stk.push(aNode);
        while (true)
        {
            while (true)
            {
                Node* pTop = stk.top();
                if (!pTop)
                {
                    stk.pop();
                    break;
                }
                if (pTop->Left)
                {
                    stk.push(pTop->Left);
                }
                else
                {
                    break;
                }
            }
            if (stk.empty())
            {
                break;
            }
            Node* pTop = stk.top();
            stk.pop();
            if (!pTop)
            {
                break;
            }
            if (pTop->Left == pChild || pTop->Right == pChild)
            {
                pRet = pTop;
                break;
            }
            stk.push(pTop->Right);
        }
    }
 
    return pRet;
}
 
void DelNode(Node* pDel)
{
    Node* pParent = findParent(Root, pDel);
    if (!pDel->Left && !pDel->Right)
    {
        if (pParent)
        {
            if (pDel == pParent->Left)
            {
                pParent->Left = 0;
            }
            else
            {
                pParent->Right = 0;
            }
        }
        else
        {
            Root = 0;
        }
        delete pDel;
        pDel = 0;
    }
    else if (pDel->Left && !pDel->Right)
    {
        if (pParent->Left == pDel)
        {
            pParent->Left = pDel->Left;
        }
        else
        {
            pParent->Right = pDel->Left;
        }
        delete pDel;
        pDel = 0;
    }
    else if (pDel->Right && !pDel->Left)
    {
        if (pParent->Left == pDel)
        {
            pParent->Left = pDel->Right;
        }
        else
        {
            pParent->Right = pDel->Right;
        }
        delete pDel;
        pDel = 0;
    }
    else if (pDel->Right && pDel->Left)
    {
        Node* pTmp = pDel->Left;
        while (pTmp->Right)
        {
            pTmp = pTmp->Right;
        }
        std::swap(pTmp->Data, pDel->Data);
        
        Node* pTmpParent = findParent(Root, pTmp);
        if (pTmpParent->Left == pTmp)
        {
            pTmpParent->Left = pTmp->Left;
        }
        else
        {
            pTmpParent->Right = pTmp->Left;
        }
        delete pTmp;
        pTmp = 0;
    }
}
 
void Delete_tree(Node*& aNode)
{
    if (!aNode) return;
    Delete_tree(aNode->Left);
    Delete_tree(aNode->Right);
    delete aNode;
    return;
}
 
 
int main()
{
    int N;
    int element;
    setlocale(0, "rus");
    srand((unsigned)time(0));
    cout << "Введите количество элементов будующего дерева: ";
    cin >> N;
    for (int i = 0; i < N; i++)
    {
        int num = rand() % 100;
        Add(num, Root);
    }
    cout << "Вывод дерева: " << endl;
    print(Root);
    cout << endl;
 
    cout << "Удаление чётных элементов" << endl;
    Node* pEven = 0;
    while ((pEven = findEven(Root)) != 0)
    {
        DelNode(pEven);
    }
 
    cout << "Вывод дерева: " << endl;
    print(Root);
    cout << endl;
 
    cout << "Добавление новых элементов : Введите количество элементов: " << endl;
    cin >> N;
    for (int i = 0; i < N; i++)
    {
        int num = rand() % 100;
        Add(num, Root);
    }
 
    cout << "Вывод дерева: " << endl;
    print(Root);
    cout << endl;
 
    Delete_tree(Root);
    cout << "Вся динамическая память очищена";
 
}
1
2 / 2 / 0
Регистрация: 23.08.2020
Сообщений: 167
04.11.2020, 16:26  [ТС]
igorrr37, Здравствуйте, помогите пожалуйста с этим заданием: Удаление максимального и минимального числа
0
2 / 2 / 0
Регистрация: 23.08.2020
Сообщений: 167
06.11.2020, 12:22  [ТС]
oleg-m1973, Здравствуйте, извините что не по теме, помогите мне пожалуйста с заданием: Удаление максимального и минимального числа
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.11.2020, 12:22
Помогаю со студенческими работами здесь

Функция: есть ли в бинарном дереве внутренний узел, у которого только один потомок?
Здравствуйте. Помогите пожалуйста. Надо написать функцию,проверяющую есть ли в дереве внутренний узел, у которого только один потомок. ...

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

Все элементы массива, которые больше девяти, заменить девятками, а все элементы, которые меньше пяти, – пятерками
Задан одномерный массив А. Все элементы массива, которые больше девяти, заменить девятками, а все элементы, которые меньше пяти, –...

В бинарном дереве определить число узлов у которых есть указатель только на одну ветвь.
Помогите плз. Нужен код на определение числа узлов у которых есть указатель только на одну ветвь. код дерева #include&lt;iostream.h&gt;...

Вывести все гласные буквы, которые встречаются хотя бы в одном слове и все согласные, которые входят только в одно слово
Дан текст на английском языке, оканчивающийся точкой. Вывести на экран все гласные буквы, которые встречаются хотя бы в одном слове; все...


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

Или воспользуйтесь поиском по форуму:
24
Ответ Создать тему
Новые блоги и статьи
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений. . . .
21 мат мед. Планы на развитие модели здравоСохранения
anaschu 01.06.2026
AnyLogic: план развития симуляционной модели рабочего коллектива — динамический абсентеизм, реальные данные, три сценария сравнения Продолжаю серию постов о дискретно-событийной модели рабочего. . .
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
Модель здравосохранения 18. Чем здоровее работник, тем быстрее выгорает
anaschu 24.05.2026
Имитационная модель корпоративного здравоохранения: что показывает математика Сегодня в модели рабочего коллектива на AnyLogic появились три новые механики — выгорание через накопленную усталость,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru