Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Итераторы и алгоритмы, взаимодействие 2-го с первым 
V
    Опции темы
Ramamba
Дата 31.3.2009, 10:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 4
Регистрация: 15.2.2009

Репутация: нет
Всего: нет



Есть следующая проблема: написан свой контейнер (подобие листа) и итератор для него. Перегружены все операторы, требуемые для итератора произвольного доступа за исключением "->". Теперь надо сделать так, чтобы с этим итератором мог работать стандартный алгоритм (например, find_if). Не могли бы подсказать, наличие каких методов ожидается от итератора. Буду рад и просто ссылке на какой-нибудь ресурс,  где такая проблема поднимается или хорошей книжке.

PS Задание состоит в том, что бы всё написать с нуля, поэтому такой выход, как наследование от std::iterator не рассматривается.
PM MAIL   Вверх
korbian
Дата 31.3.2009, 11:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 336
Регистрация: 20.2.2007
Где: Penza

Репутация: 2
Всего: 14



повтори интерфейс стандартного list (информация здесь: std::list), реализуй под него Итератор (суть паттерна можно посмотреть тут: паттерн Итератор). если все реализуешь правильно, работать будет. будут сложности приводи код!!!


--------------------
korbian ©
PM   Вверх
vinter
Дата 31.3.2009, 11:28 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Explorer
****


Профиль
Группа: Завсегдатай
Сообщений: 2735
Регистрация: 1.4.2006
Где: Н.Новгород

Репутация: 13
Всего: 56



Цитата(Ramamba @  31.3.2009,  11:29 Найти цитируемый пост)
Не могли бы подсказать, наличие каких методов ожидается от итератора.

operator *
operator ->
operator =
operator ++
operator ++(int)
operator --(int)
operator <
operator !=
operator ==

вроде достаточно


--------------------
Мой блог
PM MAIL WWW   Вверх
Daevaorn
Дата 31.3.2009, 11:33 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2155
Регистрация: 29.11.2004
Где: Москва

Репутация: 51
Всего: 70



Цитата(Ramamba @  31.3.2009,  11:29 Найти цитируемый пост)
Перегружены все операторы, требуемые для итератора произвольного доступа за исключением "->"

Цитата(Ramamba @  31.3.2009,  11:29 Найти цитируемый пост)
Не могли бы подсказать, наличие каких методов ожидается от итератора.

http://www.kuzbass.ru:8086/docs/isocpp/lib...or.requirements
PM MAIL WWW   Вверх
Ramamba
Дата 31.3.2009, 14:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 4
Регистрация: 15.2.2009

Репутация: нет
Всего: нет



спасибо, буду копать)
PM MAIL   Вверх
maxim1000
Дата 31.3.2009, 16:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник
Сообщений: 3334
Регистрация: 11.1.2003
Где: Киев

Репутация: 17
Всего: 110



ещё можно посмотреть boost::iterator_facade
даже если его не использовать, можно будет посмотреть список того, что он предоставляет


--------------------
qqq
PM WWW   Вверх
Ramamba
Дата 31.3.2009, 22:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 4
Регистрация: 15.2.2009

Репутация: нет
Всего: нет



ЕЕЕ парни, спасибо вам. Особенно тебе, Daevaorn
Покопался в этой документации, добавил в итератор тайпдефов
Код

            typedef T& reference;
            typedef T* pointer;
            typedef long difference_type;
            typedef T value_type;
            typedef std::random_access_iterator_tag iterator_category;

и всё заработало. Алгоритм find_if выбрал из моего листа всё, что надо

Это сообщение отредактировал(а) Ramamba - 31.3.2009, 22:12
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1139 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.