最終更新日時(UTC):
が更新

履歴 編集

function template
<unordered_set>

std::unordered_set::insert_range(C++23)

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

概要

コンテナにRangerg の要素を挿入する。

効果

Rangerg のすべての要素 t に対して、insert(t) を呼び出した場合と等価。

事前条件

*this の要素の範囲と Rangerg の要素の範囲が重複していないこと

テンプレートパラメータ制約

value_type は、コンテナに対して EmplaceConstructible であること

戻り値

なし

計算量

N = ranges::distance(rg) とすると、平均的なケースでは O(N)、最悪のケースでは O(N size() + 1)

#include <iostream>
#include <unordered_set>
#include <vector>

int main ()
{
    std::unordered_set<int> s = {1, 2, 3};

    std::vector<int> v = {2, 3, 4};
    s.insert_range(v);

    for (int i : s) {
        std::cout << i << " ";
    }
    std::cout << std::endl;

    return 0;
}

出力

4 3 2 1 

関連項目

名前 説明
insert 要素の追加