名前空間
変種
操作

std::forward_list<T,Allocator>::insert_range_after

From cppreference.com
 
 
 
 
template< container-compatible-range<T> R >
iterator insert_range_after( const_iterator pos, R&& rg );
(C++23から)

rg の要素のコピーを、逆順ではない順序で pos の後(before)に挿入します。範囲 rg 内の各イテレータはちょうど1回だけ間接参照されます。

pos は、範囲 [begin()end()) 内のデリファレンス可能な任意のイテレータ、または before_begin() イテレータでなければなりません(したがって、end()pos の有効な引数ではありません)。

イテレータや参照は無効になりません。

rg がコンテナと重なる場合、動作は未定義です。

目次

[編集] パラメータ

pos - コンテンツが挿入されるイテレータ
rg - コンテナ互換範囲。つまり、要素が T に変換可能な input_range
型要件
-
*ranges::begin(rg) から forward_list への EmplaceConstructible である必要があります。そうでなければ、動作は未定義です。

[編集] 戻り値

forward_list に挿入された最後の要素のコピーを指す iterator、または rg が空の場合は pos を指すイテレータ。

[編集] 計算量

rg のサイズに対して線形。

[編集] 注釈

機能テストマクロ 規格 機能
__cpp_lib_containers_ranges 202202L (C++23) ranges対応の構築と挿入

[編集]

#include <algorithm>
#include <cassert>
#include <forward_list>
#include <iterator>
#include <vector>
 
int main()
{
    auto container = std::forward_list{1, 2, 3, 4};
    auto pos = std::next(container.cbegin());
    assert(*pos == 2);
    const auto rg = std::vector{-1, -2, -3};
 
#ifdef __cpp_lib_containers_ranges
    container.insert_range_after(pos, rg);
#else
    container.insert_after(pos, rg.cbegin(), rg.cend());
#endif
 
    assert(std::ranges::equal(container, std::vector{1, 2, -1, -2, -3, 3, 4}));
}

[編集] 関連項目

先頭に要素の範囲を追加する
(public member function)
指定した要素の直後に要素を挿入する
(public member function)
指定した要素の直後に要素を直接構築する
(public member function)
English 日本語 中文(简体) 中文(繁體)