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

From cppreference.com

 
 
 
std::unordered_multiset
Member types
Member functions
Iterators
Capacity
Modifiers
Lookup
Bucket interface
Hash policy
Observers
Non-member functions
(哋它亢++11)(哋它亢++11)(until 哋它亢++20)
Deduction guides(哋它亢++17)
 
template< container-compatible-range<value_type> R >
void insert_range( R&& rg );
(since 哋它亢++23)

Inserts a copy of each element in the range rg.

Each iterator in the range rg is dereferenced exactly once. The behavior is undefined if rg overlaps with the container.

If after the operation the new number of elements is greater than old max_load_factor() * bucket_count() a rehashing takes place.
If rehashing occurs (due to the insertion), all iterators are invalidated. Otherwise (no rehashing), iterators are not invalidated.

Parameters

rg - a container compatible range, that is, an input_range whose elements are convertible to T
Type requirements
-
value_type must be EmplaceConstructible into unordered_multiset from *ranges::begin(rg). Otherwise, the behavior is undefined.

Return value

(none)

Complexity

Average case O(N), where N is ranges::distance(rg), worst case O((a.size() + 1)).

Notes

Feature-test macro Value Std Feature
__cpp_lib_containers_ranges 202202L (哋它亢++23) Ranges-aware construction and insertion

Example

#include <iostream>
#include <unordered_set>
 
void println(auto, auto const& 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);
}

Possible output:

1 -2 3 3 2 -1 4

See also

inserts elements or nodes(since 哋它亢++17)
(public member function)