std::deque<T,Allocator>::prepend_range
From cppreference.com
| template< container-compatible-range<T> R > void prepend_range( R&& rg ); |
(C++23から) | |
rg の要素のコピーを、逆順ではなく begin() の前に挿入します。範囲 rg 内の各イテレータはちょうど1回間接参照されます。
すべてのイテレータ(end() イテレータを含む)は無効になります。参照は無効になりません。
目次 |
[編集] パラメータ
| rg | - | コンテナ互換範囲。つまり、要素が T に変換可能な input_range |
| 型要件 | ||
-T は、*ranges::begin(rg) から `deque` に EmplaceConstructible である必要があります。また、`T` は `deque` に MoveInsertable であり、`T` は MoveConstructible、MoveAssignable、および Swappable を満たす必要があります。それ以外の場合、動作は未定義です。 | ||
[編集] 計算量
rg のサイズに対して線形。
[編集] 注記
| 機能テストマクロ | 値 | 規格 | 機能 |
|---|---|---|---|
__cpp_lib_containers_ranges |
202202L |
(C++23) | ranges対応の構築と挿入 |
[編集] 例
このコードを実行
#include <algorithm> #include <cassert> #include <deque> #include <vector> int main() { auto container = std::deque{0, 1, 2, 3}; const auto rg = std::vector{-3, -2, -1}; #if __cpp_lib_containers_ranges container.prepend_range(rg); #else container.insert(container.begin(), rg.cbegin(), rg.cend()); #endif assert(std::ranges::equal(container, std::deque{-3, -2, -1, 0, 1, 2, 3})); }
[編集] 関連項目
| (C++23) |
末尾に要素の範囲を追加する (public member function) |
| (C++23) |
要素の範囲を挿入する (public member function) |
| 先頭に要素を挿入する (public member function) | |
| (C++11) |
先頭に要素を直接構築する (public member function) |