|
3 / 3 / 0
Регистрация: 21.11.2010
Сообщений: 194
|
|||||||||||
Красно-черное дерево (класс, шаблон и его реализация)20.06.2012, 17:38. Показов 11641. Ответов 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
Класс красно-черное дерево: исправить ошибку Красно-черное дерево Красно-черное дерево |
|
Модератор
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,244
|
|
| 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, красно-черное, декартово) Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|