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

STL Бинарные деревья с++

04.05.2017, 21:54. Показов 7894. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер.
Хочу узнать подробно о бинарных деревьях в STL.
После поиска по интернету наткнулся на :

STL бинарное дерево

Где сказано что в STL не реализованы бинарные деревья.
Дальнейший поиск не дал особо никаких результатов.
Знаю что в STL есть контейнер (Multi)Set и (Multi)Map которые по описанию являются бинарными деревьями.
Пожалуйста, объясните что к чему.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.05.2017, 21:54
Ответы с готовыми решениями:

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

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

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

8
 Аватар для GoldenId
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 877
Записей в блоге: 10
04.05.2017, 22:13
http://www.cplusplus.com/refer... w=multimap
Multimaps are typically implemented as binary search trees.
http://www.cplusplus.com/refer... w=multiset
Multisets are typically implemented as binary search trees.
Не являются бинарными деревьями, а используют бинарные деревья для реализации своей функциональности. Внутри они могут быть бинарными деревьями (IB), но наружу этого интерфейса не выдают.
0
0 / 0 / 1
Регистрация: 07.02.2017
Сообщений: 40
04.05.2017, 22:38  [ТС]
Можете предоставить небольшой код (Создания дерева с использованием контейнеров)
0
 Аватар для GoldenId
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 877
Записей в блоге: 10
04.05.2017, 23:35
C++
1
2
3
4
5
6
#include <map>
 
int main()
{
     std::map<char, int> m;
}
если map реализовано через двоичные деревья поиска.
1
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
05.05.2017, 09:20
В STL нет бинарных деревьев.
Если структуры данных, которые основаны на бинарных деревьях, хоть это и не является обязательным фактором и не прописано в стандарте.
При этом там, как правило, самобалансирующиеся деревья (обычно используют К/Ч деревья), а это частный случай бинарных.

Добавлено через 4 минуты
Как пример (не самой лучшей) реализации
Деревья
Функцию для освобождения памяти надо добавить + по хорошему всё это в класс/шаблон класса запихать.
Но, наверное, новичкам будет проще с таким кодом работать т.к. писал его тот же новичок (я), лет 6 назад.
0
0 / 0 / 1
Регистрация: 07.02.2017
Сообщений: 40
05.05.2017, 14:31  [ТС]
Примерно понял принцип создания, но не понимаю вывод на консоль.
На консоль выводится просто отсортированный порядок чисел.
А если я хочу узнать сколько листьев в дереве, или хочу узел удалить ?
0
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
05.05.2017, 14:49
Цитата Сообщение от Akalit Посмотреть сообщение
На консоль выводится просто отсортированный порядок чисел.
Ну так это ж суть рекурсивного обхода. Как вы ещё хотите дерево вывести?

Добавлено через 12 секунд
Цитата Сообщение от Akalit Посмотреть сообщение
А если я хочу узнать сколько листьев в дереве, или хочу узел удалить ?
Пишите свои функции.
0
0 / 0 / 1
Регистрация: 07.02.2017
Сообщений: 40
05.05.2017, 14:58  [ТС]
Как я понимаю с таким же успехом можно написать свои функции к ?
C++
1
2
3
4
5
6
#include <map>
 
int main()
{
     std::map<char, int> m;
}
0
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
05.05.2017, 15:00
Цитата Сообщение от Akalit Посмотреть сообщение
Как я понимаю с таким же успехом можно написать свои функции к ?
Нет, не понимаете. Вы не можете знать как устроено "бинарное дерево" (если оно вообще используется в вашей реализации) внутри контейнера. Это "внутренняя кухня".
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.05.2017, 15:00
Помогаю со студенческими работами здесь

бинарные деревья
Здравствуйте! Помогите пожалуйста доделать задачу на бинарные деревья. Язык только начали изучать. Дается не очень легко. Пока...

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение Это мой обзор планшета X220 с точки зрения школьника. Недавно я решила попытаться уменьшить свой. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru