Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

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

Бинарные деревья. Ошибка нулевого указателя - C++

17.05.2017, 20:15. Просмотров 91. Ответов 1
Метки нет (Все метки)

При выполнении программы возникла следующая ошибка: ptr было nullptr. Что это значит и как ее исправить?Возникает в функции make в цикле while. Код прилагается тоже:
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
#include <iostream>
#include <conio.h>
#include <stdlib.h>
 
using namespace std;
 
struct Tree
{
    int parent;
    Tree *left;
    Tree *right;
};
 
void make(Tree **node, int a)
{
    Tree **ptr;
    
    while (a > 0)
    {
        ptr = node;
        while (*ptr != NULL)
        {
            if ((double)rand() / RAND_MAX < 5)
            {
                ptr = &((*ptr)->left);
            }
            else {
                ptr = &((*ptr)->right);
            }
            (*ptr) = new Tree();
            cout << "Введите значение" << endl;
            cin >> (*ptr)->parent;
            a--;
        }
    }
    }
    void Print(Tree *node, int b)
    {
        if (node != NULL)
        {
            Print(node->right,b+1);
        }
    }
 
    void Order(Tree*node)
    {
        if (node != NULL)
        {
            cout << node->parent;
            Order(node->left);
            Order(node ->right);
        }
}
    void postOrder(Tree*node)
    {
        if (node != NULL)
        {
            postOrder(node->left);
            cout << node->parent;
            postOrder(node->right);
        }
    }
 
    void add(Tree** node, int data)
    {
        Tree*new_node = new Tree;
        new_node->parent = data;
        new_node->left = NULL;
        new_node->right = NULL;
        Tree** ptr = node;
        while (*ptr != NULL)
        {
            double q = (double)rand() / RAND_MAX;
            if (q < 1 / 3.0)ptr = &((*ptr)->left);
            else if (q > 2 / 3.0)ptr = &((*ptr)->right);
            else break;
        }
        if (*ptr != NULL)
        {
            if ((double)rand() / RAND_MAX < 5)
            new_node->left = *ptr;
            else new_node->right = *ptr;
            *ptr = new_node;
        }
        else
        {
            *ptr = new_node;
        }
    }
 
    void del(Tree** node, int data)
    {
        if ((*node) != NULL)
        {
            if ((*node)->parent == data)
            {
                Tree*ptr = (*node);
                if ((*node)->left == NULL && (*node)->right == NULL) (*node) = NULL;
                else if ((*node)->left == NULL)(*node) = ptr->right;
                else if ((*node)->right == NULL)(*node) = ptr->left;
                else
                {
                    (*node) = ptr->right;
                    Tree**ptr1;
                    ptr1 = node;
                    while (*ptr1 != NULL)
                        ptr1 = &((*ptr1)->left);
                    (*ptr1) = ptr->left;
                }
                delete(ptr);
                del(node, data);
            }
            else
            {
                del(&((*node)->left), data);
                del(&((*node)->right), data);
            }
        }
        
    }
    
    bool empty(Tree*node)
    {
        return(node == NULL ? true : false);
    }
 
    void Delet(Tree*node)
    {
        if (node != NULL)
        {
            Delet(node->left);
            Delet(node->right);
            delete(node);
        }
 
    }
 
    int main()
    {
        setlocale(LC_ALL, "Russian");
        Tree *node = NULL;
        int a(6);
        make(&node, a);
        Print(node,a);
        _getch();
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.05.2017, 20:15
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Бинарные деревья. Ошибка нулевого указателя (C++):

Бинарные деревья - C++
Разработать набор классов упорядоченных бинарных деревьев поиска типов: вещественные числа, двоичные строки(строка из 0 и 1) и линейные...

Бинарные деревья - C++
Здравствуйте! Подскажите, правильно ли написано правое удаление вершины дерева? if(tree1-&gt;Right){ if(tree1-&gt;Right-&gt;Left==NULL){ ...

бинарные деревья - C++
Вот у меня есть программа, которая создает бинарное дерево из массива целых чисел. #include &lt;iostream&gt; #include &lt;conio.h&gt; using...

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

бинарные деревья - C++
Вершина двоичного дерева содержит указатель на строку и указатели на правое и левое поддеревья. Строки в дереве упорядочены по возрастанию....

Бинарные деревья - C++
Очень нужна помощь, вообще деревья не понимаю!!!:( Вершина дерева содержит указатель на строку и N указателей на потомков. Функция...

1
nmcf
5754 / 5065 / 1733
Регистрация: 14.04.2014
Сообщений: 20,749
18.05.2017, 09:04 #2
У тебя не учитывается случай, когда дерево пустое. И добавление должно быть, наверное, вне второго цикла. И используй лучше ссылки на указатели.
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.05.2017, 09:04
Привет! Вот еще темы с ответами:

Бинарные деревья - C++
На с++ с объектно-ориентированным подходом(тоисть с помощю класов) нужно представить арифметическое выражение типа 3*((7+1)/4)+(17-5) в...

Бинарные деревья - C++
Возникла проблема с бинарными деревьями . Нужно определить K - количество узлов, ключ которых больше заданного числа N. Я дошёл только до...

Бинарные деревья - C++
Вот задачка: Для заданного бинарного дерева поиска проверить условие: • для каждой вершины высота левого поддерева отличается от...

Бинарные деревья - C++
Компилятор выдаёт ошибки в 9, 10 и 12, 13 строках: invalid conversion from 'int' to 'sNode*' Подскажите пожалуйста, что не так. ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

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