Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.80/51: Рейтинг темы: голосов - 51, средняя оценка - 4.80
4 / 4 / 0
Регистрация: 27.12.2010
Сообщений: 56

Итератор ?

16.08.2011, 16:27. Показов 9985. Ответов 40
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как выглядит итератор на вложеный контейнер? Например осуществить доступ к 1-му символу 3-го элемента в векторе vector< <vecrot<char> > vec через индекс можно так vec[2][0]. А как через итератор?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.08.2011, 16:27
Ответы с готовыми решениями:

Реализовать двусвязный список (list), итератор (iterator) и константный итератор (сonst_iterator) для списка
не могу понять что должно быть результатом. может подскажете примеры? пожалуйста. Задание: Реализовать двусвязный список (list),...

итератор
скажите как в этой задачи перевести десятичное число в двоичное??? вот условие задачи!!! вот код!! main.h #include...

Итератор
Вот задача: Реализовать шаблон упорядоченного массива как двусвязного списка. Операцию доступа по индексу заменить итератором. Вопрос:...

40
Заблокирован
16.08.2011, 16:35
Цитата Сообщение от Romiys Посмотреть сообщение
Как выглядит итератор на вложеный контейнер? Например осуществить доступ к 1-му символу 3-го элемента в векторе vector< <vecrot<char> > vec через индекс можно так vec[2][0]. А как через итератор?
vec[ 2 ].begin();
0
4 / 4 / 0
Регистрация: 27.12.2010
Сообщений: 56
16.08.2011, 16:45  [ТС]
А вот так правильно: vec.begin()+2.begin() ? Что бы без индекса?
0
Заблокирован
16.08.2011, 16:48
( *( vec.begin() + 2 ) ).begin();
2
 Аватар для OstapBender
594 / 532 / 76
Регистрация: 22.03.2011
Сообщений: 1,585
16.08.2011, 16:49
обращение к 4 элементу 3-го вектора примерно так:
*((vec.begin()+3)->begin()+4 ) = 10;
2
4 / 4 / 0
Регистрация: 27.12.2010
Сообщений: 56
16.08.2011, 16:52  [ТС]
Всем большое спасибо!
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
16.08.2011, 16:58
Итераторы предназначены ИСКЛЮЧИТЕЛЬНО для последовательного доступа.
Остальное - специфика.
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
16.08.2011, 16:58
C++
1
std::vector<char>::iterator it = (v.begin() + 2)->begin();
1
Заблокирован
16.08.2011, 17:03
Цитата Сообщение от Deviaphan Посмотреть сообщение
Итераторы предназначены ИСКЛЮЧИТЕЛЬНО для последовательного доступа.
Остальное - специфика.
А как быть с итераторами произвольного доступа и с алгоритмами сортировки?!
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
16.08.2011, 17:34
Цитата Сообщение от Сыроежка Посмотреть сообщение
А как быть
Итератор по определению предназначен для последовательного доступа.
Остальное - специфика.
0
Заблокирован
16.08.2011, 17:36
Цитата Сообщение от Deviaphan Посмотреть сообщение
Итератор по определению предназначен для последовательного доступа.
Остальное - специфика.
Это где такое определение написано?!
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
16.08.2011, 17:38
Цитата Сообщение от Сыроежка Посмотреть сообщение
Это где такое определение написано?
В учебнике английского языка. Слово iteration посмотри.
0
Заблокирован
16.08.2011, 17:42
Цитата Сообщение от Deviaphan Посмотреть сообщение
В учебнике английского языка. Слово iteration посмотри.
Это хорошо, что вы изучили учебник английского языка. Теперь для вас самое время приступить к изучению стандарта С++, в частности почитайте главу "Итераторы", где дается описание этого понятия!
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
16.08.2011, 17:44
Цитата Сообщение от Deviaphan Посмотреть сообщение
В учебнике английского языка. Слово iteration посмотри.
Итерация (лат. iteratio — я повторяю) — в широком смысле слова: термин, обозначающий повторение какого-либо действия, явления или процесса. В узком смысле слова наиболее часто применяется для описания поэтапного процесса, в котором результаты выполнения группы операций в рамках каждого этапа используются следующим этапом (кроме последнего, потому что он предоставляет конечный результат).
Данный термин употребляется в математике, экономике, программировании, психологии и психиатрии. Применение данного термина в различных областях носит несколько различный характер, но смысл остается в рамках общепринятого значения.
Я не думаю, что словарь английского языка применим к терминам из специализированных областей
Особенно, если вспомнить такие, как on-die termination, hot swap/hot plug, etc.
Можно еще функтор вспомнить, так в C++ вообще беспредел с определением функтора.

И кстати, я думаю, тут более уместно было бы сказать, что итератор предназначен для последовательного (итеративного) применения, например в циклах, а не то чтобы итератор может быть только последовательного доступа.
0
Заблокирован
16.08.2011, 17:54
На самом деле итератор - это шаблонный класс, моделирующий указатели. А для указателей, как известно, действует арифметика указателей, то есть произвольный доступ.
И итераторы именно появились из-за того, что появилась необходимость моделировать указатели для последовательностей, к которым встроенные указатели не подходят.

Как я уже сказал, в самом начале главы "Итераторы" стандарта, дается развернутое пояснение, что такое итераторы, и для чего они созданы. Там не говорится ни о каком "исключительно последовательном доступе". Поэтому там вводятся категории итераторов.

То есть главный смысл понятия итераторов - это моделирование указателей. То есть нельзя сказать, что итераторы используются исключительно для последовательного доступа. Иначе сразу же вылетают многие алгоритмы, начиная с простого алгоритма swap.
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
16.08.2011, 18:26
Цитата Сообщение от Сыроежка Посмотреть сообщение
На самом деле итератор - это шаблонный класс, моделирующий указатели.
Скажи это итераторам по мэпу.)

Добавлено через 1 минуту
Цитата Сообщение от fasked Посмотреть сообщение
И кстати, я думаю, тут более уместно было бы сказать, что итератор предназначен для последовательного (итеративного) применения
Под последовательным доступом я именно это и имел в виду. Нужно мне яснее изъсняться.)

Добавлено через 59 секунд
v.begin()
v.begin()+1
v.begin()+2
Тоже последовательный доступ при помощи итераторов
0
Заблокирован
16.08.2011, 18:27
Цитата Сообщение от Deviaphan Посмотреть сообщение
Скажи это итераторам по мэпу.)

Добавлено через 1 минуту

Под последовательным доступом я именно это и имел в виду. Нужно мне яснее изъсняться.)

Добавлено через 59 секунд
v.begin()
v.begin()+1
v.begin()+2
Тоже последовательный доступ при помощи итераторов
Я вам еще раз повторяю: не фантазируйте, а читайте стандарт!

И это не последовательный доступ, а произвольный доступ. Так как у итераторов последовательного доступа не операции сложения с целочисленным значением!

У вас каша в голове! И полное незнание главы стандарта Итераторы.
0
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
16.08.2011, 22:14
Лучший ответ Сообщение было отмечено как решение

Решение

Цитата Сообщение от OstapBender Посмотреть сообщение
обращение к 4 элементу 3-го вектора примерно так:
*((vec.begin()+3)->begin()+4 ) = 10;
Так как выражение p[n] есть сокращенная запись выражения *(p + n), то выражение
C++
1
*( (matr.begin() + 3)->begin() + 4 )
равносильно выражению
C++
1
matr.begin()[3].begin()[4]
3
 Аватар для OstapBender
594 / 532 / 76
Регистрация: 22.03.2011
Сообщений: 1,585
17.08.2011, 01:36
Mr.X, интересное замечание. но это всё таки читерство, т.к юзается [] .
а вообще
C++
1
matr.begin()[3].begin()[4]
также можно заменить на
C++
1
matr.at(3).at(4)
а это уже почти [][]
0
бжни
 Аватар для alex_x_x
2473 / 1684 / 135
Регистрация: 14.05.2009
Сообщений: 7,162
17.08.2011, 02:04
Цитата Сообщение от Сыроежка Посмотреть сообщение
Я вам еще раз повторяю: не фантазируйте, а читайте стандарт!
итераторы как понятие существуют в программировании и вне стандарта, собственно вне стандарта они и появились
как бы там ни было основная идея итератора - обход контейнера без раскрытия особенностей его реализации, не важно ++ это, java или c# или еще бог весть что
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
17.08.2011, 02:04
Помогаю со студенческими работами здесь

итератор
Привет всем! подскажите пожалуйста литературу где подробно описана реализация итераторов ...

Итератор
#include &lt;iostream&gt; #include &lt;list&gt; using namespace std; list&lt;int&gt;::iterator pos (list&lt;int&gt; a,list&lt;int&gt;::iterator it) { for (it;...

Итератор
Добрый день. Я начинающий. Есть проект пытаюсь сделать построение-отладку выдает ошибку типа: Ошибка 1 error C2061: синтаксическая...

Итератор!!!!!
Есть такое задание: Разработать класс «Итератор», который должен содержать конструктор и функции просмотра текущего элемента, перехода к...

Итератор С++
помогите пожалуйста написать итератор, накапливающий сумму пройденных элементов!!!


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru