Namespaces
Variants

std::unordered_multiset<Key,Hash,KeyEqual,Allocator>:: equal_range

From cppreference.net

std:: pair < iterator, iterator > equal_range ( const Key & key ) ;
(1) (начиная с C++11)
std:: pair < const_iterator, const_iterator > equal_range ( const Key & key ) const ;
(2) (начиная с C++11)
template < class K >
std:: pair < iterator, iterator > equal_range ( const K & x ) ;
(3) (начиная с C++20)
template < class K >
std:: pair < const_iterator, const_iterator > equal_range ( const K & x ) const ;
(4) (начиная с C++20)
1,2) Возвращает диапазон, содержащий все элементы с ключом key в контейнере. Диапазон определяется двумя итераторами: первый указывает на первый элемент требуемого диапазона, а второй указывает на элемент, следующий за последним элементом диапазона.
3,4) Возвращает диапазон, содержащий все элементы контейнера с ключом, эквивалентным x . Эта перегрузка участвует в разрешении перегрузки только если Hash и KeyEqual являются прозрачными . Предполагается, что такой Hash может быть вызван с типами K и Key , и что KeyEqual является прозрачным, что в совокупности позволяет вызывать эту функцию без создания экземпляра Key .

Содержание

Параметры

key - значение ключа для сравнения с элементами
x - значение любого типа, которое можно прозрачно сравнить с ключом

Возвращаемое значение

std::pair содержащий пару итераторов, определяющих искомый диапазон. Если таких элементов нет, возвращаются итераторы за пределами контейнера (см. end() ) в качестве обоих элементов пары.

Сложность

В среднем линейная по количеству элементов с ключом key , в худшем случае линейная по размеру контейнера.

Примечания

Feature-test макрос Значение Стандарт Функциональность
__cpp_lib_generic_unordered_lookup 201811L (C++20) Гетерогенный поиск сравнения в неупорядоченных ассоциативных контейнерах , перегрузки (3,4)

Пример

Оценивает частоту символов для заданной строки.

#include <iostream>
#include <iterator>
#include <string>
#include <unordered_set>
int main()
{
    std::string sentence{"cppreference.net"};
    std::cout << "The sentence: " << sentence << '\n';
    std::unordered_multiset<char> sequence;
    for (char x : sentence)
        sequence.insert(x);
    std::cout << "The sequence: { ";
    for (char x : sequence)
        std::cout << x << ' ';
    std::cout << "}\n" "Symbol:Frequency: ";
    for (auto it = sequence.begin(); it != sequence.end();)
    {
        if (auto [first, last] = sequence.equal_range(*it); first != last)
        {
            std::cout << *first << ":" << std::distance(first, last) << "  ";
            it = last;
        }
        else
            ++it;
    }
}

Возможный вывод:

The sentence: cppreference.net
The sequence: { m o c c c p p r r e e e e f n . }
Symbol:Frequency: m:1  o:1  c:3  p:2  r:2  e:4  f:1  n:1  .:1

Смотрите также

находит элемент с указанным ключом
(публичная функция-член)
(C++20)
проверяет, содержит ли контейнер элемент с указанным ключом
(публичная функция-член)
возвращает количество элементов, соответствующих указанному ключу
(публичная функция-член)
возвращает диапазон элементов, соответствующих указанному ключу
(шаблон функции)