Шрифт:
При копировании, сравнении и выполнении других операций над двумя последовательностями первая из них задается парой итераторов
Некоторые алгоритмы, такие как
Многие алгоритмы придерживаются обычного соглашения и возвращают конец последовательности в качестве признака события “не найден”. Мы больше не будем упоминать об этом каждый раз, описывая очередной алгоритм.
Б.5.1. Немодицифирующие алгоритмы для последовательностей
Немодифицирующий алгоритм просто считывает элементы последовательности; он не изменяет порядок следования элементов последовательности и не изменяет их значения.
Предотвратить модификацию элементов операцией, передаваемой алгоритму
Рассмотрим пример правильного использования алгоритма.
Б.5.2. Алгоритмы, модифицирующие последовательности
Модифицирующие алгоритмы могут изменять элементы последовательностей, являющихся их аргументами.
Алгоритм
Следует подчеркнуть, что эти алгоритмы не знают, являются ли их аргументы контейнерами, поэтому не могут добавлять или удалять элементы. Таким образом, такой алгоритм, как
Результат приведен ниже.
Б.5.3. Вспомогательные алгоритмы
С формальной точки зрения вспомогательные алгоритмы также могут модифицировать последовательности, но мы считаем, что лучше их перечислить отдельно, чтобы они не затерялись в длинном списке.
Обратите внимание на то, что неинициализированные последовательности должны использоваться только на самых нижних уровнях программирования, как правило, в реализации контейнеров. Элементы, представляющие собой цели алгоритмов