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

履歴 編集

function
<flat_set>

std::flat_set::equal_range(C++23)

pair<iterator, iterator> equal_range(const key_type& x); // (1) C++23

template <class K>
pair<iterator, iterator> equal_range(const K& x);        // (2) C++23

pair<const_iterator, const_iterator>
  equal_range(const key_type& x) const;                  // (3) C++23

template <class K>
pair<const_iterator, const_iterator>
  equal_range(const K& x) const;                         // (4) C++23

概要

コンテナ内の、x と等しいキー要素を全て含む範囲の境界を返す。flat_set コンテナではキーの重複は無いため、この範囲は最大一つの要素を含む。

もし x がコンテナ内のどのキーともマッチしなかった場合、戻り値の範囲は長さ 0 になり、両方のイテレータは x より大きく最も近い値を指す。そうでない場合、x がコンテナ内の全ての要素よりも大きい場合は end を指す。

  • (1) : key_type型のキーを受け取り、そのキーと等価なキー要素を全て含むイテレータ範囲を取得する。
  • (2) : key_typeと比較可能なK型のキーを受け取り、そのキーと等価なキー要素を全て含むイテレータ範囲を取得する。
  • (3) : const*thisオブジェクトにおいて、key_type型のキーを受け取り、そのキーと等価なキー要素を全て含むイテレータ範囲を取得する。
  • (4) : const*thisオブジェクトにおいて、key_typeと比較可能なK型のキーを受け取り、そのキーと等価なキー要素を全て含むイテレータ範囲を取得する。

戻り値

この関数は pair を返す。ここで pair::firstlower_bound(x) が返すであろう値と同じ値で範囲の下境界にあたり、pair::secondupper_bound(x) が返すであろう値と同じ値で範囲の上境界にあたる。

計算量

size について対数時間。

備考

#include <flat_set>
#include <iostream>

int main()
{
  std::flat_set<int> fs = {3, 1, 4};

  using iterator = decltype(fs)::iterator;
  std::pair<iterator, iterator> ret = fs.equal_range(3);

  for (iterator it = ret.first; it != ret.second; ++it) {
    std::cout << *it << std::endl;
  }
}

出力

3

バージョン

処理系

関連項目

名前 説明
flat_set::count 指定したキーにマッチする要素の数を返す
flat_set::lower_bound 与えられた値より小さくない最初の要素へのイテレータを返す
flat_set::upper_bound 特定の値よりも大きい最初の要素へのイテレータを返す
flat_set::find 指定したキーで要素を探す