File indexing completed on 2025-01-30 09:59:16
0001
0002
0003
0004
0005
0006
0007
0008
0009 #ifndef BOOST_RANGE_ALGORITHM_BINARY_SEARCH_HPP_INCLUDED
0010 #define BOOST_RANGE_ALGORITHM_BINARY_SEARCH_HPP_INCLUDED
0011
0012 #include <boost/concept_check.hpp>
0013 #include <boost/range/begin.hpp>
0014 #include <boost/range/end.hpp>
0015 #include <boost/range/concepts.hpp>
0016 #include <algorithm>
0017
0018 namespace boost
0019 {
0020 namespace range
0021 {
0022
0023
0024
0025
0026
0027
0028
0029 template<class ForwardRange, class Value>
0030 inline bool binary_search(const ForwardRange& rng, const Value& val)
0031 {
0032 BOOST_RANGE_CONCEPT_ASSERT(( ForwardRangeConcept<const ForwardRange> ));
0033 return std::binary_search(boost::begin(rng), boost::end(rng), val);
0034 }
0035
0036
0037 template<class ForwardRange, class Value, class BinaryPredicate>
0038 inline bool binary_search(const ForwardRange& rng, const Value& val,
0039 BinaryPredicate pred)
0040 {
0041 BOOST_RANGE_CONCEPT_ASSERT(( ForwardRangeConcept<const ForwardRange> ));
0042 return std::binary_search(boost::begin(rng), boost::end(rng), val, pred);
0043 }
0044
0045 }
0046 using range::binary_search;
0047 }
0048
0049 #endif