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

Реализация декартова дерева (treap)

17.05.2019, 23:06. Показов 2929. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте, изучаю C++, написал реализацию декартова дерева, но код не работает (сложно сказать в чем именно ошибка). Прошу проверить и указать в чем причина неправильной работы.

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
#include <iostream>
#include <cstdlib>
 
using namespace std;
 
class Treap
{
public:
 
    int x, y;
    Treap *left;
    Treap *right;
 
    Treap()
    {
        left = NULL;
        right = NULL;
    }
};
 
 
struct TreapPair
{
    Treap *T1;
    Treap *T2; 
};
 
 
Treap* merge(Treap *L, Treap *R)
{
    if (L == NULL)
    {
        return R;
    }
    if (R == NULL)
    {
        return L;
    }
    else if (L->y > R->y)
    {
        L->right = merge(L->right, R);
        return L;
    }
    else
    {
        R->left = merge(L, R->left);
        return R;
    }
} 
 
 
TreapPair* split(Treap *T, int x)
{
    TreapPair *TP = new TreapPair;
 
    if (T == NULL)
    {
        TP->T1 = NULL;
    TP->T2 = NULL;
        return TP;
    }
    else
    {
        if (x > T->x)
        {
            TP = split(T->right, x);
            T->right = TP->T1;
            return TP;
        }
        else
        {
            TP = split(T->left, x);
            T->left = TP->T2;
            return TP;
        }
    }
}
 
Treap* newTreap(int x)
{
    Treap* temp = new Treap;
    temp->x = x;
    temp->y = rand()%100;
    temp->left = temp->right = NULL;
    return temp;
}
 
Treap* insert(Treap *T, int x)
{
    TreapPair* TP = new TreapPair;
 
    if (T == NULL)
    {
        T = newTreap(x);
    }
    else
    {
        Treap *new_T = newTreap(x);
        TP = split(T, x);
        TP->T1 = merge(TP->T1, new_T);
        T = merge(TP->T1, TP->T2);
        return T; 
    }
}
 
bool find(Treap *T, int x)
{
    if (T->x == x)
    {
        return true;
    }
    if (T == NULL)
    {
        return false;
    }
    else
    {
        if (T->x > x)
        {
            return find(T->left, x);
        }
        else
        {
            return find(T->right, x);
        }
    }
}
 
int main()
{
    Treap T;
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.05.2019, 23:06
Ответы с готовыми решениями:

Реализация 2-3 дерева
Помогите пожалуйста реализовать 2-3 дерево

Реализация бинарного дерева
Доброго времени суток, уважаемые форумчане. Возник вопрос по реализации бинарного дерева на С++, а...

Реализация дерева поиска
Мне крайне срочно необходимо реализовать дерево поиска на с++(чтобы пользователь сам вводил...

Реализация бинарного дерева
написать программу, реализующую бинарное дерево. Предусмотреть процедуры и функции: инициализация...

0
17.05.2019, 23:06
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.05.2019, 23:06
Помогаю со студенческими работами здесь

Реализация дерева на указателях
Задание такое:Пусть А, В,С – деревья соответствующего типа, узлы которых могут содержать...

Реализация бинарного дерева классом
Добрый вечер. Написал класс class TreeClass { int number; TreeClass *left, *right; public:...

Реализация бинарного дерева поиска
Задача: Реализация бинарного дерева поиска Компилируется нормально, а при запуске выбивает ошибку...

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


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

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