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

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

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

Author24 — интернет-сервис помощи студентам
Почему удаляются только те чётные элементы которые я добавил, а не все которые есть в бинарном дереве?
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)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
29.10.2020, 10:40
Ответы с готовыми решениями:

Почему удаляются не все строки, которые соответствуют условию?
Мне нужно удалить записи за неделю У меня есть такой запрос: DELETE FROM kassa WHERE...

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

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

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

23
2 / 2 / 0
Регистрация: 23.08.2020
Сообщений: 167
02.11.2020, 15:40  [ТС] 21
Author24 — интернет-сервис помощи студентам
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
2859 / 2006 / 988
Регистрация: 21.12.2010
Сообщений: 3,711
Записей в блоге: 10
02.11.2020, 18:56 22
Цитата Сообщение от 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  [ТС] 23
igorrr37, Здравствуйте, помогите пожалуйста с этим заданием: Удаление максимального и минимального числа
0
2 / 2 / 0
Регистрация: 23.08.2020
Сообщений: 167
06.11.2020, 12:22  [ТС] 24
oleg-m1973, Здравствуйте, извините что не по теме, помогите мне пожалуйста с заданием: Удаление максимального и минимального числа
0
06.11.2020, 12:22
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
06.11.2020, 12:22
Помогаю со студенческими работами здесь

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

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

В бинарном дереве определить число узлов у которых есть указатель только на одну ветвь.
Помогите плз. Нужен код на определение числа узлов у которых есть указатель только на одну ветвь....

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

Объединить 2 списка в один, элементы которого будут только те элементы, которые есть в первом, но нет во втором
Например '(1 2 4 7 8) '(3 5 8 2 0 5) Результат - '(1 4 7)

Исключить из массива все четные элементы, которые стоят на нечетных местах
Как сделать программу когда вводиться массив из 10 елементов и все парные элементы которые стоят на...


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

Или воспользуйтесь поиском по форуму:
24
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru