◐ Shell
clean mode source ↗

制約付きアルゴリズム (C++20以上) - cppreference.com

C++20 ではほとんどのアルゴリズムの制約付きバージョンが名前空間 std::ranges で提供されます。 これらのアルゴリズムでは、範囲は iteratorsentinel の組としてまたは単一の range 引数として指定することができ、射影とメンバポインタの callable がサポートされます。 さらに、ほとんどのアルゴリズムの戻り値の型はアルゴリズムの実行中に計算される役に立つかもしれないすべての情報を返すように変更されています。

ヘッダ <algorithm> で定義

名前空間 std::ranges で定義

非変更シーケンス操作
指定範囲内の要素のすべて、1個以上、または0個に対して述語が true を返すかどうか調べます
(ニーブロイド) [edit] 指定範囲の要素に関数を適用します
(ニーブロイド) [edit] 特定の基準を満たす要素の数を返します
(ニーブロイド) [edit] 2つの範囲が異なる最初の位置を探します
(ニーブロイド) [edit] 2つの集合の要素が同じかどうか判定します
(ニーブロイド) [edit] ある範囲が別の範囲より辞書順で小さい場合に true を返します
(ニーブロイド) [edit] 特定の基準を満たす最初の要素を探します
(ニーブロイド) [edit] 特定の範囲内の要素の最後のシーケンスを探します
(ニーブロイド) [edit] 要素の集合のいずれかを検索します
(ニーブロイド) [edit] 最初の等しい (または指定の述語を満たす) 隣接する2つの項目を探します
(ニーブロイド) [edit] 指定範囲の要素に対して検索を行います
(ニーブロイド) [edit] 指定個数の連続する指定要素を指定範囲から検索します
(ニーブロイド) [edit]
変更シーケンス操作
指定範囲の要素を新しい位置にコピーします
(ニーブロイド) [edit] 指定個数の要素を新しい位置にコピーします
(ニーブロイド) [edit] 指定範囲の要素を逆順にコピーします
(ニーブロイド) [edit] 指定範囲の要素を新しい位置にムーブします
(ニーブロイド) [edit] 指定範囲の要素を新しい位置に逆順でムーブします
(ニーブロイド) [edit] 特定の値を指定範囲の要素に代入します
(ニーブロイド) [edit] 値を指定個数の要素に代入します
(ニーブロイド) [edit] 指定範囲の要素に関数を適用します
(ニーブロイド) [edit] 関数の結果を指定範囲に保存します
(ニーブロイド) [edit] 関数の N 回の適用の結果を保存します
(ニーブロイド) [edit] 特定の基準を満たす要素を削除します
(ニーブロイド) [edit] 特定の基準を満たす要素を省きながら指定範囲の要素をコピーします
(ニーブロイド) [edit] 特定の基準を満たすすべての値を別の値に置き換えます
(ニーブロイド) [edit] 特定の基準を満たす要素を別の値で置換しながら範囲をコピーします
(ニーブロイド) [edit] 2つの範囲の要素を入れ替えます
(ニーブロイド) [edit] 指定範囲の要素の順序を反転させます
(ニーブロイド) [edit] 指定範囲の逆順のコピーを作成します
(ニーブロイド) [edit] 指定範囲の要素の順序を回転させます
(ニーブロイド) [edit] 指定範囲の要素をコピーして回転させます
(ニーブロイド) [edit] 措定範囲の要素をランダムに並べ替えます
(ニーブロイド) [edit] 指定範囲の連続する重複要素を削除します
(ニーブロイド) [edit] 連続する重複を含まない要素の範囲のコピーを作成します
(ニーブロイド) [edit]
分割操作
指定範囲が指定の述語で分割されているかどうか判定します
(ニーブロイド) [edit] 指定範囲の要素を2つのグループに分割します
(ニーブロイド) [edit] 要素を2つのグループに分割しながら指定範囲をコピーします
(ニーブロイド) [edit] 相対順序を維持しながら要素を2つのグループに分割します
(ニーブロイド) [edit] 分割済み範囲の分割点を探します
(ニーブロイド) [edit]
ソート操作
指定範囲が昇順にソートされているかどうか調べます
(ニーブロイド) [edit] 最も大きなソート済み部分範囲を探します
(ニーブロイド) [edit] 指定範囲を昇順にソートします
(ニーブロイド) [edit] 指定範囲の最初の N 個の要素をソートします
(ニーブロイド) [edit] 指定範囲の要素をコピーして部分的にソートします
(ニーブロイド) [edit] 等しい要素間の順序を維持しながら指定範囲の要素をソートします
(ニーブロイド) [edit] 指定要素で分割されることを保証しながら指定範囲を部分的にソートします
(ニーブロイド) [edit]
二分探索操作 (ソート済み範囲用)
指定された値より小さくない最初の要素を指すイテレータを返します
(ニーブロイド) [edit] 特定の値より大きい最初の要素を指すイテレータを返します
(ニーブロイド) [edit] 特定の範囲に要素が存在するかどうか判定します
(ニーブロイド) [edit] 特定のキーにマッチする要素の範囲を返します
(ニーブロイド) [edit]
集合操作 (ソート済み範囲用)
2つのソート済み範囲をマージします
(ニーブロイド) [edit] 2つの順序付き範囲をその場でマージします
(ニーブロイド) [edit] ある集合が別の集合の部分集合であれば true を返します
(ニーブロイド) [edit] 2つの集合の差を計算します
(ニーブロイド) [edit] 2つの集合の交差を計算します
(ニーブロイド) [edit] 2つの集合の対称差を計算します
(ニーブロイド) [edit] 2つの集合の和を計算します
(ニーブロイド) [edit]
ヒープ操作
指定された範囲が最大ヒープかどうか調べます
(ニーブロイド) [edit] 最大ヒープである最も大きな部分範囲を探します
(ニーブロイド) [edit] 指定範囲の要素から最大ヒープを作成します
(ニーブロイド) [edit] 最大ヒープに要素を追加します
(ニーブロイド) [edit] 最大ヒープから最も大きな要素を削除します
(ニーブロイド) [edit] 最大ヒープを昇順にソートされた要素の範囲に変換します
(ニーブロイド) [edit]
最小/最大演算
指定された値の大きい方を返します
(ニーブロイド) [edit] 指定範囲の最も大きな要素を返します
(ニーブロイド) [edit] 指定された値の小さい方を返します
(ニーブロイド) [edit] 指定範囲の最も小さな要素を返します
(ニーブロイド) [edit] 2つの要素の小さい方と大きい方を返します
(ニーブロイド) [edit] 指定範囲の最も小さな要素と最も大きな要素を返します
(ニーブロイド) [edit]
順列操作
シーケンスが別のシーケンスの順列かどうか判定します
(ニーブロイド) [edit] 指定範囲の要素より辞書的に大きな次の順列を生成します
(ニーブロイド) [edit] 指定範囲の要素より辞書的に小さな次の順列を生成します
(ニーブロイド) [edit]