0 / 0 / 0
Регистрация: 18.10.2010
Сообщений: 3
1

Класс контейнера, реализующий интерфейс

18.10.2010, 15:49. Показов 2846. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Всем доброго времени суток. Возник вопрос по выполнению задания. Вот само задание:

Необходимо разработать класс контейнера, реализующий приведенный ниже
интерфейс. При разработке допускается использовать STL. Кроме этого,
внутренняя реализация ничем не ограничена.

C++
1
2
3
4
5
6
7
8
9
10
class ElemNotFound {};
 template < class ElemType, class IndexType > class IContainer
 {
 public:
 virtual const ElemType& GetElem( const IndexType& index ) const
throw ( ElemNotFound ) = 0;
 
 virtual void PutElem( const IndexType& index, const ElemType& elem )
 throw () = 0;
 };
Решение:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
template <class ElemType, class IndexType> class CContainer: public IContainer < ElemType, IndexType > 
{ 
private:
std::vector<ElemType> elems;
std::vector<IndexType> indexes;
 
public:
virtual const ElemType& GetElem( const IndexType& index ) const throw ( ElemNotFound ){
for(int i=0;i<elems.size();i++)
{ 
if((IndexType)indexes[i]==index) //перегрузка оператора == в IndexType
return elems[i]; 
}
throw ElemNotFound();
};
 
virtual void PutElem( const IndexType& index, const ElemType& elem ) throw (){
elems.push_back(elem);
indexes.push_back(index);
};
CContainer(){};
~CContainer(){};
};
Вроде бы код работает нормально, но решение засчитали неправильным. Что сделал не так?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
18.10.2010, 15:49
Ответы с готовыми решениями:

Класс контейнера, реализующий интерфейс
Может у кого нибудь есть какие то идеи по этому: Необходимо реализовать класс контейнера,...

Класс, реализующий множество
Создать класс реализующий множество целых чисел. Доп. условия: Элементы множества хранить в...

Класс, реализующий стек
Помогите девушке, только учусь программировать и чет пока не очень=( плиииииииииииииииииииииииииз...

Описать класс, реализующий возможности
Часы. установка времени; перевод на летнее время; перевод на зимнее время; вывести текущее время;...

3
Эксперт С++
1674 / 1046 / 174
Регистрация: 27.09.2009
Сообщений: 1,945
18.10.2010, 18:40 2
Слово index во множественном числе пишется indices.
if((IndexType)indexes[i]==index) - преобразование к IndexType здесь не нужно совершенно - обе сравниваемые величины и так имеют этот самый тип.
В IContainer деструктор следовало бы объявить виртуальным и с пустым телом (не pure). В CContainer объявления конструктора и деструктора не нужны.
Ну а кроме этих мелочей и некоторой некрасивости общей идеи (что, впрочем, не мешает ей достигать поставленных целей) проблем не вижу...
1
0 / 0 / 0
Регистрация: 18.10.2010
Сообщений: 3
18.10.2010, 19:49  [ТС] 3
if((IndexType)indexes[i]==index) - преобразование к IndexType здесь не нужно совершенно - обе сравниваемые величины и так имеют этот самый тип.
Пробовал сделать без приведения к типу IndexType, но в таком случаи вылезала ошибка:
Error 6 error C2678: binary '==' : no operator found which takes a left-hand operand of type 'const IndexType' (or there is no acceptable conversion) c:\users\darklin\documents\visual studio 2008\projects\test_dr_web\test_dr_web\container.h 18
Я решил, что это из-за того, что при обращении к vector'у через оператор [] возвращаемый элемент имеет тип const IndexType, а для него оператор == не перегружен.

В классе IndexType перегружен так:

C++
1
2
3
4
bool operator==(IndexType index)
    {   
        return this->a==index.a;
    };
0
Эксперт С++
1674 / 1046 / 174
Регистрация: 27.09.2009
Сообщений: 1,945
18.10.2010, 22:08 4
Оператор сравнения должен быть константным, ведь он не изменяет содержимое индекса.
C++
1
bool IndexType::operator == (const IndexType& index) const;
0
18.10.2010, 22:08
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
18.10.2010, 22:08
Помогаю со студенческими работами здесь

Написать класс, реализующий Стек
Написать класс, реализующий стек или очередь (что указано в задании). В классе описать...

Класс, реализующий стек точек
описание класса ,реализующего стек точек R2(int ,int) очень нужно,плиииз

Описать класс, реализующий стек
Всем привет, нуждаюсь в помощи. Описать класс, реализующий стек. Написать программу, использующую...

Описать класс, реализующий стек
Очень нужна хоть какая-нибудь помощь! У меня никак не получается написать программу а заказывать...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru