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

履歴 編集

function
<flat_set>

std::flat_multiset::equal_range

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 と等しいキー要素を全て含む範囲の境界を返す。

もし 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>
#include <string>

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

  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
3

バージョン

処理系

関連項目

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