Skip to content

Latest commit

 

History

History
85 lines (63 loc) · 3.33 KB

equal_range.md

File metadata and controls

85 lines (63 loc) · 3.33 KB

equal_range

  • flat_map[meta header]
  • std[meta namespace]
  • flat_multimap[meta class]
  • function[meta id-type]
  • cpp23[meta cpp]
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
  • pair[link /reference/utility/pair.md]

概要

コンテナ内の、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() について対数時間。

備考

  • (2), (4) : この関数がオーバーロード解決に参加する条件は、find()メンバ関数の備考欄を参照。

#include <flat_map>
#include <iostream>
#include <string>

int main()
{
  std::flat_multimap<std::string, int> fm = {
    {"A", 3},
    {"B", 1},
    {"B", 4},
    {"C", 5}
  };

  using iterator = decltype(fm)::iterator;
  std::pair<iterator, iterator> ret = fm.equal_range("B");

  for (iterator it = ret.first; it != ret.second; ++it) {
    std::cout << it->first << ", " << it->second << std::endl;
  }
}
  • equal_range[color ff0000]

出力

B, 1
B, 4

関連項目

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