|
0 / 0 / 0
Регистрация: 03.01.2020
Сообщений: 15
|
|
Бинарное дерево поиска03.01.2020, 10:07. Показов 4236. Ответов 14
Здравствуйте! Сегодня я попытался самостоятельно изучить деревья и начал с бинарного дерева поиска. Нашёл статью с кодом на одном очень хорошем сайте. Очень долго пытался понять, что и зачем тут нужно (даже комментарии к коду мне не очень помогли). В общем, вот код, но компилятор ругается на строчку, которую я выделил. Помогите, пожалуйста, исправить.
#include <iostream> #include <cstdlib> using namespace std; /*-----TREE-----*/ typedef struct tree { int key; struct tree *left; struct tree *right; struct tree *parent; } node; /*-----CREATE-----*/ node *create (node *root, int key) { node *tmp = malloc (sizeof(node)); tmp -> key = key; tmp -> parent = NULL; tmp -> left = tmp -> right = NULL root = tmp; return root; } /*-----ADD_ELEMENT-----*/ node *add (node *root, int key) { node *root2 = root, *root3 = NULL; node *tmp = malloc(sizeof(node)); tmp -> key = key; while (root2 != NULL) { root3 = root2; if (key < root2 -> key) { root2 = root2 -> left; } else { root2 = root2 -> right; } } tmp -> parent = root3; tmp -> left = tmp -> right = NULL; if (key < root3 -> key) { root3 -> left = tmp; } else { root3 -> right = tmp; } } /*-----SEARCH-----*/ node *search (node *root, int key) { if ((root -> key == NULL) || (root -> key == key)) { return root; } if (key < root -> key) { return search(root -> left, key); } else { return search(root -> right, key); } } int main () { node *tree = new node; int n; cin >> n; // тут я попытался инициализировать дерево, а дальше я не могу понять, что нужно указывать в аргументах, чтобы добавить ещё узлы create(tree, n); return 0; }
0
|
|
| 03.01.2020, 10:07 | |
|
Ответы с готовыми решениями:
14
Исходное бинарное дерево превратить в бинарное дерево поиска, при этом сохранив его структуру Бинарное дерево поиска Бинарное дерево поиска |
|
"C with Classes"
|
|||||||
| 03.01.2020, 10:14 | |||||||
Сообщение было отмечено Andrey15year как решение
Решение
malloc тип void* возвращает, привидение необходимо.
1
|
|||||||
|
0 / 0 / 0
Регистрация: 03.01.2020
Сообщений: 15
|
|
| 03.01.2020, 10:26 [ТС] | |
|
теперь ругается на
root = tmp;
0
|
|
|
"C with Classes"
|
||
| 03.01.2020, 10:35 | ||
|
Добавлено через 2 минуты что функция node *create (node *root, int key) должна делать?
0
|
||
|
0 / 0 / 0
Регистрация: 03.01.2020
Сообщений: 15
|
|
| 03.01.2020, 10:37 [ТС] | |
|
Всё, я нашёл ошибку, ";" не поставил XD, но всё равно спасибо)
0
|
|
|
"C with Classes"
|
|
| 03.01.2020, 10:38 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 03.01.2020
Сообщений: 15
|
|
| 03.01.2020, 10:40 [ТС] | |
|
Создаёт корень дерева
0
|
|
|
"C with Classes"
|
|||||||
| 03.01.2020, 10:41 | |||||||
0
|
|||||||
|
0 / 0 / 0
Регистрация: 03.01.2020
Сообщений: 15
|
|
| 03.01.2020, 10:42 [ТС] | |
|
0
|
|
|
"C with Classes"
|
|||
| 03.01.2020, 10:46 | |||
|
Добавлено через 2 минуты
1
|
|||
|
0 / 0 / 0
Регистрация: 03.01.2020
Сообщений: 15
|
|
| 03.01.2020, 10:47 [ТС] | |
|
0
|
|
|
"C with Classes"
|
|||||||
| 03.01.2020, 10:48 | |||||||
0
|
|||||||
|
0 / 0 / 0
Регистрация: 03.01.2020
Сообщений: 15
|
|
| 03.01.2020, 10:53 [ТС] | |
|
0
|
|
|
"C with Classes"
|
|||||||
| 03.01.2020, 11:23 | |||||||
Сообщение было отмечено Andrey15year как решение
Решение
1
|
|||||||
| 03.01.2020, 11:23 | |
|
Помогаю со студенческими работами здесь
15
Бинарное дерево поиска Бинарное дерево поиска
Бинарное дерево поиска C++ Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html
Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
|
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
|
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях.
Задача: при копировании документа очищать определенные реквизиты и табличную. . .
|