Namespaces
Variants

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

From cppreference.net

template < container-compatible-range < value_type > R >
void insert_range ( R && rg ) ;
(desde C++23)
(constexpr desde C++26)

Inserta una copia de cada elemento en el rango rg .

Cada iterador en el rango rg es desreferenciado exactamente una vez.

Si se satisface cualquiera de las siguientes condiciones, el comportamiento es indefinido:

Si después de la operación el nuevo número de elementos es mayor que el antiguo max_load_factor() * bucket_count() ocurre una redistribución (rehashing).
Si ocurre redistribución (debido a la inserción), todos los iteradores quedan invalidados. En caso contrario (sin redistribución), los iteradores no se invalidan.

Contenidos

Parámetros

rg - un rango compatible con contenedor , es decir, un input_range cuyos elementos son convertibles a T

Complejidad

Caso promedio N , peor caso O(N·S+N) , donde S es size ( ) y N es ranges:: distance ( rg ) .

Notas

Macro de prueba de características Valor Std Característica
__cpp_lib_containers_ranges 202202L (C++23) Construcción e inserción compatibles con rangos

Ejemplo

#include <iostream>
#include <unordered_set>
void println(auto, const auto& container)
{
    for (const auto& elem : container)
        std::cout << elem << ' ';
    std::cout << '\n';
}
int main()
{
    auto container = std::unordered_multiset{1, 3, 2, 4};
    const auto rg = {-1, 3, -2};
#ifdef __cpp_lib_containers_ranges
    container.insert_range(rg);
#else
    container.insert(rg.begin(), rg.end());
#endif
    println("{}", container);
}

Salida posible:

1 -2 3 3 2 -1 4

Véase también

inserta elementos o nodos (desde C++17)
(función miembro pública)