table of contents
        
      
      
    - Tumbleweed 2024.07.05-1.3
 - Leap-16.0
 - Leap-15.6
 
| std::binary_search(3) | C++ Standard Libary | std::binary_search(3) | 
NAME¶
std::binary_search - std::binary_search
Synopsis¶
 Defined in header <algorithm>
  
   template< class ForwardIt, class T >
  
   (constexpr since
  
   bool binary_search( ForwardIt first, C++20)
  
   ForwardIt last, (until C++26)
  
   const T& value );
  
   template< class ForwardIt, class T =
  
   typename std::iterator_traits
  
   <ForwardIt>::value_type > (since C++26)
  
   constexpr bool binary_search( ForwardIt
  
   first, ForwardIt last,
  
   const T&
  
   value );
  
   template< class ForwardIt, class T, class
  
   Compare > (1)
  
   (constexpr since
  
   bool binary_search( ForwardIt first, C++20)
  
   ForwardIt last, (until C++26)
  
   const T& value,
  
   Compare comp );
  
   template< class ForwardIt, class T =
  
   typename std::iterator_traits (2)
  
   <ForwardIt>::value_type,
  
   class Compare > (since C++26)
  
   constexpr bool binary_search( ForwardIt
  
   first, ForwardIt last,
  
   const T&
  
   value, Compare comp );
  
   Checks if an element equivalent to value appears within the partitioned range
  
   [first, last).
  
   1) The equivalence is checked using operator<:
  
   If !bool(*iter < value) && !bool(value < *iter) is true for
    some
  
   iterator iter in [first, last), returns true. Otherwise returns false.
  
   If any of the following conditions is satisfied, the behavior is
  
   undefined: (until C++20)
  
   * For any element elem of [first, last), bool(elem < value) does not
  
   imply !bool(value < elem).
  
   * The elements elem of [first, last) are not partitioned with
  
   respect to expressions bool(elem < value) and !bool(value < elem).
  
   Equivalent to std::binary_search(first, last, value, std::less{}). (since
    C++20)
  
   2) The equivalence is checked using comp:
  
   If !bool(comp(*iter, value)) && !bool(comp(value, *iter)) is true for
    some iterator
  
   iter in [first, last), returns true. Otherwise returns false.
  
   If any of the following conditions is satisfied, the behavior is undefined:
  
   * For any element elem of [first, last), bool(comp(elem, value)) does not
    imply
  
   !bool(comp(value, elem)).
  
   * The elements elem of [first, last) are not partitioned with respect to
  
   expressions bool(comp(elem, value)) and !bool(comp(value, elem)).
Parameters¶
 first, last - the partitioned range of elements to examine
  
   value - value to compare the elements to
  
   binary predicate which returns true if the first argument is ordered
  
   before the second.
  
   The signature of the predicate function should be equivalent to the
  
   following:
  
   bool pred(const Type1 &a, const Type2 &b);
  
   comp - While the signature does not need to have const &, the function
    must
  
   not modify the objects passed to it and must be able to accept all
  
   values of type (possibly const) Type1 and Type2 regardless of value
  
   category (thus, Type1 & is not allowed
  
   , nor is Type1 unless for Type1 a move is equivalent to a copy
  
   (since C++11)).
  
   The types Type1 and Type2 must be such that an object of type T can be
  
   implicitly converted to both Type1 and Type2, and an object of type
  
   ForwardIt can be dereferenced and then implicitly converted to both
  
   Type1 and Type2.
Type requirements¶
 -
  
   ForwardIt must meet the requirements of LegacyForwardIterator.
  
   -
  
   Compare must meet the requirements of BinaryPredicate. It is not required to
    satisfy
  
   Compare.
Return value¶
true if an element equivalent to value is found, false otherwise.
Complexity¶
Given \(\scriptsize N\)N as std::distance(first, last):
  
   1) At most \(\scriptsize \log_{2}(N)+O(1)\)log
  
   2(N)+O(1) comparisons with value using
  
   operator<
  
   (until C++20)
  
   std::less{}
  
   (since C++20).
  
   2) At most \(\scriptsize \log_{2}(N)+O(1)\)log
  
   2(N)+O(1) applications of the comparator comp.
  
   However, if ForwardIt is not a LegacyRandomAccessIterator, the number of
    iterator
  
   increments is linear in \(\scriptsize N\)N.
Notes¶
 Although std::binary_search only requires [first, last) to be
    partitioned, this
  
   algorithm is usually used in the case where [first, last) is sorted, so that
    the
  
   binary search is valid for any value.
  
   std::binary_search only checks whether an equivalent element exists. To
    obtain an
  
   iterator to that element (if exists), std::lower_bound should be used
    instead.
  
   Feature-test macro Value Std Feature
  
   __cpp_lib_algorithm_default_value_type 202403 (C++26) List-initialization for
  
   algorithms (1,2)
Possible implementation¶
See also the implementations in libstdc++ and libc++.
  
   binary_search (1)
  
   template<class ForwardIt, class T = typename
    std::iterator_traits<ForwardIt>::value_type>
  
   bool binary_search(ForwardIt first, ForwardIt last, const T& value)
  
   {
  
   return std::binary_search(first, last, value, std::less{});
  
   }
  
   binary_search (2)
  
   template<class ForwardIt, class T = typename
    std::iterator_traits<ForwardIt>::value_type,
  
   class Compare>
  
   bool binary_search(ForwardIt first, ForwardIt last, const T& value,
    Compare comp)
  
   {
  
   first = std::lower_bound(first, last, value, comp);
  
   return (!(first == last) and !(comp(value, *first)));
  
   }
Example¶
// Run this code
  
   #include <algorithm>
  
   #include <cassert>
  
   #include <complex>
  
   #include <iostream>
  
   #include <vector>
  
   int main()
  
   {
  
   const auto haystack = {1, 3, 4, 5, 9};
  
   for (const auto needle : {1, 2, 3})
  
   {
  
   std::cout << "Searching for " << needle << '\n';
  
   if (std::binary_search(haystack.begin(), haystack.end(), needle))
  
   std::cout << "Found " << needle << '\n';
  
   else
  
   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::binary_search(nums.cbegin(), nums.cend(), {4, 2}, cmpz));
  
   #else
  
   assert(std::binary_search(nums.cbegin(), nums.cend(), CD{4, 2}, cmpz));
  
   #endif
  
   }
Output:¶
 Searching for 1
  
   Found 1
  
   Searching for 2
  
   no dice!
  
   Searching for 3
  
   Found 3
  
   Defect reports
  
   The following behavior-changing defect reports were applied retroactively to
  
   previously published C++ standards.
  
   DR Applied to Behavior as published Correct behavior
  
   Compare was required to satisfy only a partitioning is required;
  
   LWG 270 C++98 Compare and T was required heterogeneous comparisons
  
   to be LessThanComparable (strict permitted
  
   weak ordering required)
  
   at most \(\scriptsize corrected to \(\scriptsize
  
   LWG 787 C++98 \log_{2}(N)+2\)log \log_{2}(N)+O(1)\)log
  
   2(N)+2 comparisons were allowed 2(N)+O(1)
See also¶
 equal_range returns range of elements matching a specific key
  
   (function template)
  
   returns an iterator to the first element not less than the
  
   lower_bound given value
  
   (function template)
  
   returns an iterator to the first element greater than a
  
   upper_bound certain value
  
   (function template)
  
   ranges::binary_search determines if an element exists in a partially-ordered
    range
  
   (C++20) (niebloid)
| 2024.06.10 | http://cppreference.com |