Программирование. Принципы и практика использования C++ Исправленное издание, стр. 426
Б.4.8. Размер и емкость
Размер — это количество элементов в контейнере; емкость — это количество элементов, которое контейнер может содержать до того, как потребуется дополнительно увеличить память

Изменяя размер или емкость, можно переместить элементы в новое место. Из этого следует, что итераторы (а также указатели и ссылки) на элементы могут стать некорректными (т.е. относиться к старым адресам).
Б.4.9. Другие операции
Контейнеры можно копировать (см. раздел Б.4.3), сравнивать и обменивать.

Если сравнение контейнеров производится с помощью соответствующего оператора (например,
<<Б.4.10. Операции над ассоциативными контейнерами
Ассоциативные контейнеры обеспечивают поиск на основе ключей.

Упорядоченные ассоциативные контейнеры (
mapsetset<K,C>CKПервый итератор пары, возвращенной функцией
equal_rangelower_boundupper_boundMarianmultimap<string,int>string k = "Marian";typedef multimap<string,int>::iterator MI;pair<MI,MI> pp = m.equal_range(k);if (pp.first!=pp.second) cout << "elements with value ' " << k << " ':\n";else cout << "no element with value ' " << k << " '\n";for (MI p = pp.first; p!=pp.second; ++p) cout << p–>second << '\n';В качестве альтернативы можно выполнить следующую эквивалентную инструкцию:
pair<MI,MI> pp = make_pair(m.lower_bound(k),m.upper_bound(k));Однако эта инструкция выполняется вдвое дольше. Алгоритмы
equal_rangelower_boundupper_boundpairБ.5. Алгоритмы
В заголовке
<algorithm>При копировании, сравнении и выполнении других операций над двумя последовательностями первая из них задается парой итераторов
[b:e]b2[b2:b2+(e–b)]Некоторые алгоритмы, такие как
sortfindМногие алгоритмы придерживаются обычного соглашения и возвращают конец последовательности в качестве признака события “не найден”. Мы больше не будем упоминать об этом каждый раз, описывая очередной алгоритм.
Б.5.1. Немодицифирующие алгоритмы для последовательностей
Немодифицирующий алгоритм просто считывает элементы последовательности; он не изменяет порядок следования элементов последовательности и не изменяет их значения.

Предотвратить модификацию элементов операцией, передаваемой алгоритму
for_each==Рассмотрим пример правильного использования алгоритма.
bool odd(int x) { return x&1; }int n_even(const vector<int>& v) // подсчитывает количество четных // чисел в v{ return v.size()–count_if(v.begin(),v.end(),odd);}Б.5.2. Алгоритмы, модифицирующие последовательности
Модифицирующие алгоритмы могут изменять элементы последовательностей, являющихся их аргументами.

Алгоритм
shuffleСледует подчеркнуть, что эти алгоритмы не знают, являются ли их аргументы контейнерами, поэтому не могут добавлять или удалять элементы. Таким образом, такой алгоритм, как
removetypedef vector<int>::iterator VII;void print_digits(const string& s, VII b, VII e)