满足有序性,每次排除一半的可能性。
int bin_search(vector<int> &arr,int v) {
int hi = arr.size() - 1;
int lo = 0;
while ( lo <= hi)
{
int mid = (lo + hi) >> 1;
if (arr[mid] < v)
lo = mid + 1;
else
hi = mid - 1;
}
return hi;
}
lower_bound()
lower_bound(potions.begin(), potions.end(), tar);
template<class ForwardIt, class T>
ForwardIt lower_bound(ForwardIt first, ForwardIt last, const T& value)
{
ForwardIt it;
typename std::iterator_traits<ForwardIt>::difference_type count, step;
count = std::distance(first, last);
while (count > 0)
{
it = first;
step = count / 2;
std::advance(it, step);
if (*it < value)
{
first = ++it;
count -= step + 1;
}
else
count = step;
}
return first;
}
upper_bound()
upper_bound(potions.begin(), potions.end(), tar);
template<class ForwardIt, class T>
ForwardIt upper_bound(ForwardIt first, ForwardIt last, const T& value)
{
ForwardIt it;
typename std::iterator_traits<ForwardIt>::difference_type count, step;
count = std::distance(first, last);
while (count > 0)
{
it = first;
step = count / 2;
std::advance(it, step);
if (!(value < *it))
{
first = ++it;
count -= step + 1;
}
else
count = step;
}
return first;
}