Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
WhiteChemist
0 / 0 / 10
Регистрация: 16.11.2016
Сообщений: 86
#1

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

17.05.2017, 20:15. Просмотров 102. Ответов 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++):

Бинарные деревья
1)Написать программу подсчета числа вершин в бинарном дереве 2)Написать...

Бинарные деревья
Здравствуйте господа. Очень нуждаюсь в вашей помощи по бинарным деревьям. ...

Бинарные деревья С++
Добрый день! Дали такое задание на лабораторную работу. кое-что получилось,...

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

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

Бинарные деревья
Подсчитать количество элементов на n-уровне бинарного дерева. Подскажите как...

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

Бинарные деревья
Доброго времени суток, нужна помощь, дали задание...Вершина бинарного дерева...

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

Бинарные деревья
Компилятор выдаёт ошибки в 9, 10 и 12, 13 строках: invalid conversion from...

Бинарные деревья
Здравствуйте! Подскажите, правильно ли написано правое удаление вершины дерева?...


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

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

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