С Новым годом! Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.52/21: Рейтинг темы: голосов - 21, средняя оценка - 4.52
0 / 0 / 0
Регистрация: 08.01.2014
Сообщений: 3

Реализация красно-черного дерева в виде двусторонней очереди

08.01.2014, 17:01. Показов 4090. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер, обитатели форума! Пишу программу, в которой есть иерархия: Дом - Квартира - Житель. Большинство вещей уже написал, но не могу разобраться с деревом. Двусторонняя очередь, думаю, вполне понятна, обычный класс Квартира, который хранит множество классов Житель, и имеющий функции добавления/удаления с начала/конца очереди.

Таким образом, в программе должно получиться дерево деревьев, каждое из которых реализовано в виде дэка. Если кто может, подскажите, как сюда впихнуть красно-черное дерево Что использовать, где воткнуть хотя-бы)

Заранее бесконечно благодарен!

P.S.Знаю, что тема данного дерева многократно обсуждалась на форуме, и действительно алгоритмы я нашел бесценными, но прошу именно индивидуальной помощи)

P.P.S. вот и моё творение
Вложения
Тип файла: rar v1.rar (92.0 Кб, 23 просмотров)
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
08.01.2014, 17:01
Ответы с готовыми решениями:

Реализация красно-черного дерева
Нужна помощь с красно-черным деревом;) Как свести эти части кода в одно целое, нужно чтобы после ввода каждого нового элемента, выводился...

Максимально простая реализация красно-чёрного дерева
Здравствуйте, извините что тема не заставит напрячь Вас свои шестерёнки. Мне необходима МАКСИМАЛЬНО ПРОСТАЯ реализация на с++...

Реализация шаблона двусторонней очереди в виде "гибкого" массива
Реализовать шаблон двусторонней очереди в виде "гибкого" массива, взяв за образец динамический растущий массив. Добавление и удаление...

5
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
08.01.2014, 18:47
Цитата Сообщение от nataniel garro Посмотреть сообщение
как сюда впихнуть красно-черное дерево
Что такое "Красно-черное дерево"?
1
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
08.01.2014, 19:01
Цитата Сообщение от Grishaco Посмотреть сообщение
Что такое "Красно-черное дерево"?
Структура данных.
2
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
08.01.2014, 19:04
kolorotur, спасибо не знал, вернее не сталкивался.

Цитата Сообщение от nataniel garro Посмотреть сообщение
Если кто может, подскажите, как сюда впихнуть красно-черное дерево Что использовать, где воткнуть хотя-бы)
Чем просто дерево не подходит?
1
0 / 0 / 0
Регистрация: 08.01.2014
Сообщений: 3
08.01.2014, 19:20  [ТС]
Цитата Сообщение от Grishaco Посмотреть сообщение
Чем просто дерево не подходит?

Ну даже если рассмотреть обычное самобалансирующееся бинарное дерево, вопрос остается прежним)

Добавлено через 9 минут
Подскажите, через что можно реализовать обычное дерево в с#? либо если есть любые примеры их реализации на этом языке, и если не сложно, не могли бы выложить?
0
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
08.01.2014, 19:35
Лучший ответ Сообщение было отмечено tezaurismosis как решение

Решение

Возможно не то, но все же посмотрите, я ваши классы по обрезал оставил только каркасы

Кликните здесь для просмотра всего текста

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
internal class Tree : BaseTree<ITree>
    {
        public Tree(Tree root, ITree obj) : base(root, obj)
        {
        }
    }
 
    internal class BaseTree<T>
    {
        private readonly List<BaseTree<T>> _child = new List<BaseTree<T>>();
 
        public BaseTree(BaseTree<T> root, T obj)
        {
            Entity = obj;
            if (root != null)
            {
                root.ChildNode.Add(this);
            }
        }
 
        public T Entity { get; set; }
 
        public List<BaseTree<T>> ChildNode
        {
            get { return _child; }
        }
    }
 
    internal interface ITree
    {
        NodeType NodeType { get; }
    }
 
    internal enum NodeType
    {
        House,
        Apartment,
        Inhabitant
    }
 
    internal class House : ITree
    {
        #region Implementation of ITree
 
        public NodeType NodeType
        {
            get { return NodeType.House; }
        }
 
        #endregion
    }
 
    internal class Apartment : ITree
    {
        #region Implementation of ITree
 
        public NodeType NodeType
        {
            get { return NodeType.Apartment; }
        }
 
        #endregion
    }
 
    internal class Inhabitant : ITree
    {
        #region Implementation of ITree
 
        public NodeType NodeType
        {
            get { return NodeType.Inhabitant; }
        }
 
        #endregion
    }


И вот вариант заполнения

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
var root = new Tree(null,null);
 
            //Добавляем 10 домов
            for (int i = 0; i < 10; i++)
            {
                var house = new Tree(root, new House());
 
                //В каждый дом по десять квартир
                for (int j = 0; j < 10; j++)
                {
                    var apartment = new Tree(house, new Apartment());
 
                    //В каждую квартиру по десять жителей
                    for (int k = 0; k < 10; k++)
                    {
                        new Tree(apartment, new Inhabitant());
                    }
                }
 
                //Добавим еще в каждый дом по одному бомжу
                new Tree(house, new Inhabitant());
            }
            
            //Далее root это самый верхний узел
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.01.2014, 19:35
Помогаю со студенческими работами здесь

Принципиальные отличия Красно-черного дерева
Читаю википедию, и не понимаю, в чем отличия красно-черного дерева от просто бинарного дерева? Для чего дополнительное введение цвета...

Комменты к реализации Красно-черного и АВЛ дерева
Люди добрые помогите разобрать и по возможности написать комментарии к этим 2м кодам .. Это коды Реализации Красно-черного и АВЛ дереве и...

Пример кода создания красно - чёрного дерева (RB - tree)
Если можно с комментариями

Алгоритм форматного вывода на экран красно-черного дерева
Доброго времени суток, форумчане! Прошу помощи в написании кода для вывода на экран элементов красно-черного дерева. структура...

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


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru