名前空間
変種
操作

std::ranges::binary_search

From cppreference.com
< cpp‎ | algorithm‎ | ranges
 
 
アルゴリズムライブラリ
制約付きアルゴリズムとRangeアルゴリズム (C++20)
制約付きアルゴリズム、例: ranges::copy, ranges::sort, ...
実行ポリシー (C++17)
シーケンスを変更しない操作
一括操作
(C++17)
検索操作
(C++11)                (C++11)(C++11)

シーケンスを変更する操作
コピー操作
(C++11)
(C++11)
スワップ操作
変換操作
生成操作
削除操作
順序変更操作
(C++17まで)(C++11)
(C++20)(C++20)
サンプリング操作
(C++17)

ソートおよび関連操作
パーティション操作
ソート操作
二分探索操作
(パーティション化された範囲)
集合操作 (ソート済み範囲)
マージ操作 (ソート済み範囲)
ヒープ操作
最小/最大操作
(C++11)
(C++17)
辞書順比較操作
順列操作
Cライブラリ
数値演算
未初期化メモリに対する操作
 
制約付きアルゴリズム
このメニューのすべての名前は名前空間 `std::ranges` に属します
シーケンスを変更しない操作
シーケンスを変更する操作
パーティション操作
ソート操作
二分探索操作 (ソート済み範囲)
       
       
binary_search
    
集合操作 (ソート済み範囲)
ヒープ操作
最小/最大操作
       
       
順列操作
畳み込み操作
数値演算
(C++23)            
未初期化ストレージに対する操作
戻り値の型
 
ヘッダー <algorithm> で定義
呼び出しシグネチャ
(1)
template< std::forward_iterator I, std::sentinel_for<I> S,

          class T, class Proj = std::identity,
          std::indirect_strict_weak_order
              <const T*, std::projected<I, Proj>> Comp = ranges::less >
constexpr bool binary_search( I first, S last, const T& value,

                              Comp comp = {}, Proj proj = {} );
(C++20以降)
(C++26まで)
template< std::forward_iterator I, std::sentinel_for<I> S,

          class Proj = std::identity,
          class T = std::projected_value_t<I, Proj>,
          std::indirect_strict_weak_order
              <const T*, std::projected<I, Proj>> Comp = ranges::less >
constexpr bool binary_search( I first, S last, const T& value,

                              Comp comp = {}, Proj proj = {} );
(C++26以降)
(2)
template< ranges::forward_range R,

          class T, class Proj = std::identity,
          std::indirect_strict_weak_order
              <const T*, std::projected<ranges::iterator_t<R>,
                                        Proj>> Comp = ranges::less >
constexpr bool binary_search( R&& r, const T& value,

                              Comp comp = {}, Proj proj = {} );
(C++20以降)
(C++26まで)
template< ranges::forward_range R,

          class Proj = std::identity,
          class T = std::projected_value_t<ranges::iterator_t<R>, Proj>,
          std::indirect_strict_weak_order
              <const T*, std::projected<ranges::iterator_t<R>,
                                        Proj>> Comp = ranges::less >
constexpr bool binary_search( R&& r, const T& value,

                              Comp comp = {}, Proj proj = {} );
(C++26以降)
1) value に投影された要素と等しい要素が範囲 [firstlast) 内に存在するかどうかをチェックします。
2) (1) と同じですが、ソース範囲として r を使用し、ranges::begin(r)firstranges::end(r)last として使用するかのようです。

ranges::binary_search が成功するためには、範囲 [firstlast)value に関して少なくとも部分的に順序付けられている必要があります。すなわち、以下のすべての要件を満たす必要があります。

  • std::invoke(comp, std::invoke(proj, element), value) に関してパーティション化されている(すなわち、式が true となる投影された要素が、式が false となるすべての要素の前に来る)。
  • !std::invoke(comp, value, std::invoke(proj, element)) に関してパーティション化されている。
  • すべての要素について、std::invoke(comp, std::invoke(proj, element), value)true の場合、!std::invoke(comp, value, std::invoke(proj, element))true です。

完全にソートされた範囲はこれらの基準を満たします。

このページで説明されている関数のようなエンティティは、アルゴリズム関数オブジェクト(非公式にはニーブロイドとして知られている)です。つまり、

目次

[編集] Parameters

first, last - 調査する要素の範囲を定義するイテレータとセンチネルのペア
r - 調査する要素の範囲
value - 要素と比較する値
comp - 射影された要素に適用する比較関数
proj - 要素に適用する射影

[編集] Return value

true value と等しい要素が見つかった場合、それ以外の場合は false

[編集] Complexity

firstlast の間の距離の対数(最大 log2(last - first) + O(1) 回の比較および投影)で比較と投影の回数が実行されます。ただし、イテレータ-センチネルペアが std::random_access_iterator をモデル化しない場合、イテレータのインクリメント回数は線形になります。

[編集] Notes

std::ranges::binary_search は、投影された要素が value と等しい要素が見つかった場合でも、その要素へのイテレータを返しません。イテレータが必要な場合は、代わりに std::ranges::lower_bound を使用してください。

機能テストマクロ 規格 機能
__cpp_lib_algorithm_default_value_type 202403 (C++26) アルゴリズム (1,2) のためのリスト初期化

[編集] Possible implementation

struct binary_search_fn
{
    template<std::forward_iterator I, std::sentinel_for<I> S,
             class Proj = std::identity, class T = std::projected_value_t<I, Proj>,
             std::indirect_strict_weak_order
                 <const T*, std::projected<I, Proj>> Comp = ranges::less>
    constexpr bool operator()(I first, S last, const T& value,
                              Comp comp = {}, Proj proj = {}) const
    {
        auto x = ranges::lower_bound(first, last, value, comp, proj);
        return (!(x == last) && !(std::invoke(comp, value, std::invoke(proj, *x))));
    }
 
    template<ranges::forward_range R, class Proj = std::identity,
             class T = std::projected_value_t<ranges::iterator_t<R>, Proj>,
             std::indirect_strict_weak_order
                 <const T*, std::projected<ranges::iterator_t<R>,
                                           Proj>> Comp = ranges::less>
    constexpr bool operator()(R&& r, const T& value, Comp comp = {}, Proj proj = {}) const
    {
        return (*this)(ranges::begin(r), ranges::end(r), value,
                       std::move(comp), std::move(proj));
    }
};
 
inline constexpr binary_search_fn binary_search;

[編集] Example

#include <algorithm>
#include <cassert>
#include <complex>
#include <iostream>
#include <ranges>
#include <vector>
 
int main()
{
    constexpr static auto haystack = {1, 3, 4, 5, 9};
    static_assert(std::ranges::is_sorted(haystack));
 
    for (const int needle : std::views::iota(1)
                          | std::views::take(3))
    {
        std::cout << "Searching for " << needle << ": ";
        std::ranges::binary_search(haystack, needle)
            ? std::cout << "found " << needle << '\n'
            : std::cout << "no dice!\n";
    }
 
    using CD = std::complex<double>;
    std::vector<CD> nums{{1, 1}, {2, 3}, {4, 2}, {4, 3}};
    auto cmpz = [](CD x, CD y){ return abs(x) < abs(y); };
    #ifdef __cpp_lib_algorithm_default_value_type
        assert(std::ranges::binary_search(nums, {4, 2}, cmpz));
    #else
        assert(std::ranges::binary_search(nums, CD{4, 2}, cmpz));
    #endif
}

出力

Searching for 1: found 1
Searching for 2: no dice!
Searching for 3: found 3

[編集] See also

特定のキーに一致する要素の範囲を返す
(アルゴリズム関数オブジェクト)[編集]
与えられた値より小さくない最初の要素へのイテレータを返す
(アルゴリズム関数オブジェクト)[編集]
特定の値より大きい最初の要素へのイテレータを返す
(アルゴリズム関数オブジェクト)[編集]
範囲が指定された要素または部分範囲を含むかチェックする
(アルゴリズム関数オブジェクト)[編集]
部分的に順序付けられた範囲に要素が存在するかどうかを判断する
(関数テンプレート) [編集]
English 日本語 中文(简体) 中文(繁體)