Первый итератор пары, возвращенной функцией equal_range
lower_bound
, а второй — upper_bound
. Вы можете вывести на печать значения всех элементов, имеющих ключ "Marian
" в контейнере multimap
, написав следующий код:string k = "Marian";
typedef multimap
pair
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
Однако эта инструкция выполняется вдвое дольше. Алгоритмы equal_range
lower_bound
и upper_bound
можно выполнять также для упорядоченных последовательностей (раздел Б.5.4). Определение класса pair
приведено в разделе Б.6.3. Б.5. Алгоритмы
В заголовке
При копировании, сравнении и выполнении других операций над двумя последовательностями первая из них задается парой итераторов [b:e]
b2
, который считается началом последовательности, содержащей элементы, количество которых достаточно для выполнения алгоритма, например, столько же, сколько элементов в первой последовательности: [b2:b2+(e–b)]
.Некоторые алгоритмы, такие как sort
find
, только считывают элементы с помощью однонаправленного итератора.Многие алгоритмы придерживаются обычного соглашения и возвращают конец последовательности в качестве признака события “не найден”. Мы больше не будем упоминать об этом каждый раз, описывая очередной алгоритм.
Б.5.1. Немодицифирующие алгоритмы для последовательностей
Немодифицирующий алгоритм просто считывает элементы последовательности; он не изменяет порядок следования элементов последовательности и не изменяет их значения.
Предотвратить модификацию элементов операцией, передаваемой алгоритму for_each
==
) недопустима.Рассмотрим пример правильного использования алгоритма.
bool odd(int x) { return x&1; }
int n_even(const vector
// чисел в v
{
return v.size–count_if(v.begin,v.end,odd);
}
Б.5.2. Алгоритмы, модифицирующие последовательности
Модифицирующие алгоритмы могут изменять элементы последовательностей, являющихся их аргументами.
Алгоритм shuffle
Следует подчеркнуть, что эти алгоритмы не знают, являются ли их аргументы контейнерами, поэтому не могут добавлять или удалять элементы. Таким образом, такой алгоритм, как remove
typedef vector
void print_digits(const string& s, VII b, VII e)
{
cout << s;
while (b!=e) { cout << *b; ++b; }
cout << '\n';
}
void ff
{
int a[] = { 1,1,1,2,2,3,4,4,4,3,3,3,5,5,5,5,1,1,1 };
vector
print_digits("all: ",v.begin, v.end);
vector
print_digits("head: ",v.begin,pp);
print_digits("tail: ",pp,v.end);
pp=remove(v.begin,pp,4);
print_digits("head: ",v.begin,pp);
print_digits("tail: ",pp,v.end);
}
Результат приведен ниже.
all: 1112234443335555111
head: 1234351
tail: 443335555111
head: 123351