|
3 / 3 / 0
Регистрация: 21.11.2010
Сообщений: 194
|
|||||||||||
Красно-черное дерево (класс, шаблон и его реализация)20.06.2012, 17:38. Показов 11566. Ответов 14
Метки нет (Все метки)
всем привет, у меня возникла проблема в создании шаблона, в обычном виде т.е. в не шаблонном, он работает нормально НО как только пытаюсь сделать шаблон и поставить везде куда надо template так тут же куча ошибок
вот хедер RBTree.h
RBTree.cpp
Ошибка 1 error C2079: "RBTree<Keytype>::Node::key" использует неопределенный class "Keytype" c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.h 16 Ошибка 2 error C2649: typename: не является "class" c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.cpp 137 Ошибка 3 error C1004: непредвиденное обнаружение конца файла c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.cpp 298 подскажите пож-та что делать или как исправить это я уже вчера и сегодня борюсь с этим Добавлено через 1 час 30 минут разве тут нет программистов которые делают шаблоны и хорошо знают правильность оформления его? или некому помочь и подсказать в правильности написания шаблона? я же не прошу код или алгоритм или всю программу написать...
0
|
|||||||||||
| 20.06.2012, 17:38 | |
|
Ответы с готовыми решениями:
14
Класс красно-черное дерево: исправить ошибку Красно-черное дерево Красно-черное дерево |
|
Модератор
13769 / 10962 / 6491
Регистрация: 18.12.2011
Сообщений: 29,236
|
|
| 20.06.2012, 17:54 | |
|
А с какой стати в 18 строчку h файла попала точка с запятой?
0
|
|
|
3 / 3 / 0
Регистрация: 21.11.2010
Сообщений: 194
|
||||||||||||
| 20.06.2012, 20:33 [ТС] | ||||||||||||
|
вот Ошибка 1 error C2533: RBTree<Keytype>: конструкторы не разрешены для возвращаемого типа c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.h 19 Ошибка 2 error C2533: RBTree<Keytype>: конструкторы не разрешены для возвращаемого типа c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.h 19 Ошибка 3 error C2079: "RBTree<Keytype>::Node::key" использует неопределенный class "Keytype" c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.h 16 Ошибка 8 error C2533: RBTree<Keytype>: конструкторы не разрешены для возвращаемого типа c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.h 19 Ошибка 9 error C2533: RBTree<Keytype>: конструкторы не разрешены для возвращаемого типа c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.h 19 Ошибка 4 error C2556: RBTree<Keytype>::RBTree(void): перегруженная функция отличается от "RBTree<Keytype>::RBTree(void)" только возвращаемым типом c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.cpp 11 Ошибка 5 error C2371: RBTree<Keytype>::RBTree: переопределение; различные базовые типы c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.cpp 11 Ошибка 6 error C2649: typename: не является "class" c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.cpp 137 Ошибка 7 error C1004: непредвиденное обнаружение конца файла c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.cpp 298 12 IntelliSense: class "RBTree<Keytype>" не содержит члена "RBTree" c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.cpp 10 Добавлено через 2 часа 30 минут немного подшманив
RBTree<int> *TreeID=new RBTree<int>; и вот что пишет, подскажите что сделать то надо?... в чем проблема?? Ошибка 1 error LNK2019: ссылка на неразрешенный внешний символ "public: __thiscall RBTree<int>::RBTree<int>(void)" (??0?$RBTree@H@@QAE@XZ) в функции "void __cdecl `dynamic initializer for 'TreeID''(void)" (??__ETreeID@@YAXXZ) C:\Users\eddilou\documents\visual studio 2010\Projects\realtorPRO\realtorPRO\real torPRODlg.obj Ошибка 2 error LNK1120: 1 неразрешенных внешних элементов C:\Users\eddilou\documents\visual studio 2010\Projects\realtorPRO\Debug\realtorPR O.exe 1
1
|
||||||||||||
|
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
|
|
| 20.06.2012, 20:37 | |
|
реализация шаблона должна быть в h файле либо в инлайн файле, который включается в конец h файла, к котором задекларирован шаблон. по хорошему вам нужно всю реализацию из c++ файла перенести в h файл. удалить из проекта спп файл
0
|
|
|
3 / 3 / 0
Регистрация: 21.11.2010
Сообщений: 194
|
||
| 20.06.2012, 20:44 [ТС] | ||
|
RBTree<class Keytype>::Node sentinel = { NIL, NIL, 0, BLACK, 0, NULL} вот эту инициализацию он ругает пишет типа мол поставьте точку с запятой или типа тут должно быть действие или что в этом роде, как то иным путем и что делать может подскажете? и как инлайнить я просто если честно то не 2 дня с этим парюсь а наверно день 4ый пытаясь как то склеить ибо без шаблона он пашет но мне нужен шаблон для использования типов unsigned int и CString подскажите плиз
0
|
||
|
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
|
|
| 20.06.2012, 20:51 | |
|
это глобальная переменная чтоли? вообще не понимаю как такая запись компилится. в общем нужно пытаться без нее сделать. первое что приходит в голову - сделать ее привтным членом самого дерева. тогда будет минимум изменений в текущем коде. плата за это - лишний мембер в классе. но жить с этим пока что можно.
0
|
|
|
3 / 3 / 0
Регистрация: 21.11.2010
Сообщений: 194
|
||
| 20.06.2012, 20:57 [ТС] | ||
|
Ошибка 2 error C2473: sentinel: выглядит как определение функции, но без списка параметров. c:\users\eddilou\documents\visual studio 2010\projects\realtorpro\realtorpro\rbtr ee.h 19 вот что посоветуешь? потому что если NIL не будет то код работает не корректно пытался раньше делать и заменял NULLом и объяву убирал и т д код работал не корректно дабы после 3-5 добавки в нее ключа выдавалась ошибка что парент без памяти и тд
0
|
||
|
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
|
||||||
| 20.06.2012, 21:03 | ||||||
|
что-то не так делаете значит. вот упрощенный вариант для примера:
0
|
||||||
|
3 / 3 / 0
Регистрация: 21.11.2010
Сообщений: 194
|
|
| 20.06.2012, 21:07 [ТС] | |
|
DU, если я так сделаю то я могу ли при вызове дерева в другом файле допустим TreeID->root->key получать данные ведь это приватно же?? и такой вопрос можно ли в дефайне оставить NIL??
0
|
|
|
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
|
|
| 20.06.2012, 21:08 | |
|
ну сделайте рут публичным, раз из других мест до него доступ нужен.
1
|
|
|
3 / 3 / 0
Регистрация: 21.11.2010
Сообщений: 194
|
|
| 20.06.2012, 21:32 [ТС] | |
|
DU,
такой вопрос еще а как сделать чтоб допустим если я ставлю <CString> то в sentinel.key инициализация была как строка т.е. =_T("") если int то 0
0
|
|
|
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
|
|
| 20.06.2012, 22:24 | |
|
не совсем понял вопроса. попробую объяснить то, что понял.
под ключем обычно понимают не данные, а ключ к данным. допустим вы все же имеете в виду данные. у вас везде указатель на Keytype. Так вот если дерево RBTree<CString> то этот тип равняется CString. И чтобы где-то создать ключ по дефолту, достаточно позвать new Keytype(); В случае с RBTree<CString> это будет эквивалентно new CString(). Отсюда следует одно ограничение: если начать использовать такую возможность, то в дереве нельзя будет использовать с типами, у которых нет конструктора по умолчанию. Если же речь шла о не динамическом выделении, то тогда просто Keytype(); для инта это будет 0, для CString это CString() и т.п.
1
|
|
|
3 / 3 / 0
Регистрация: 21.11.2010
Сообщений: 194
|
|
| 20.06.2012, 22:42 [ТС] | |
|
DU, спасибо что пояснили теперь понял что нужно в инсерт указатель передавать а когда вызов идет то там надо & ставить у того где указатель, теперь работает как надо все а вот такой вопрос допустим имеется ключи у которых скажем так значение одинаково допусти в дереве 3 ключа со значением 15, а мне нужно найти эти ключи т.е. поиск по определенному полю я вызываю тот класс по которому ищется значение данного поля, и как сделать можно чтоб поиск не прекратился при первом же найденом но при этом нашел эти 3 ключа и вывел на экран
ps делаю все в mfc как вывести я знаю а как вот организовать тчоб не вылетел при первом найденом
0
|
|
|
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
|
|
| 20.06.2012, 23:07 | |
|
это я не знаю. в алгоритмах не силен, а копаться в деталях вашего дерева мне не очень хочется
![]() ищите в какой-нибудь классике типа Кнута или еще где-нибудь. Наверняка это дело расписано уже. если у вас дерево поддерживает несколько ключей с одинаковым значением, то можете посмотреть на интерфейс класса std::multimap<Key, Value>. И там кстати в мапину (которая устроена как дерево) не вставляются не указатели на узлы. туда ключ и значение вставляются как значения. Код, который работает с такой мапиной ничего не знает про внутренний класс вроде Node. Это деталь реализации, которую как раз нужно скрывать.
0
|
|
|
3 / 3 / 0
Регистрация: 21.11.2010
Сообщений: 194
|
|
| 20.06.2012, 23:10 [ТС] | |
|
еще такой вопрос назрел можно ли обход дерева допустим делать внутри параметра передаваемого функции т.е.
допусти при изменении скажем так полей кроме ID конечно меняется структура дерева а значит нам надо менять и само построение дерева можно ли функция которая обходя возвращает каждый кусок узла а точнее указатель на card внутри самой функции т.е. выглядит это так item *K; tree->insertNode(K->Reg, K=функция обхода) или только циклически т.е. item *K; while(K!=NULL) {K=функция обхода tree->insertNode(K->Reg,K )}
0
|
|
| 20.06.2012, 23:10 | |
|
Помогаю со студенческими работами здесь
15
Красно-черное дерево, найти ошибки в коде Красно-черное прошитое дерево с функцией добавления и удаления элементов Реализовать красно-черное дерево для хранения множества целых чисел Красно-Черное дерево ОШИБКА .exe вызвал срабатывание точки останова Ищу готовый код с примерами реализации деревьев (AVL, красно-черное, декартово) Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
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
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|