Алгоритм upper_bound()

Алгоритм upper_bound()

templateclass ForwardIterator, class Type

ForwardIterator

upper_bound( ForwardIterator first,

ForwardIterator last, const Type &value );

template class ForwardIterator, class Type, class Compare

ForwardIterator

upper_bound( ForwardIterator first,

ForwardIterator last, const Type &value,

Compare comp );

upper_bound() возвращает итератор, указывающий на последнюю позицию в отсортированной последовательности [first,last), в которую еще можно вставить значение value, не нарушая упорядоченности. Значения всех элементов, начиная с этой позиции и далее, будут больше, чем value. Например, если дана последовательность:

int ia[] = {12,15,17,19,20,22,23,26,29,35,40,51};

то обращение к upper_bound() с value=21 вернет итератор, указывающий на значение 22, а обращение с value=22 - на значение 23. В первом варианте для сравнения используется оператор "меньше", определенный для типа элементов контейнера; во втором - заданная программистом операция comp.

#include algorithm

#include vector

#include assert.h

#include iostream.h

template class Type

void print_elements( Type elem ) { cout elem " "; }

void (*pfi)( int ) = print_elements;

int main()

{

int ia[] = {29,23,20,22,17,15,26,51,19,12,35,40};

vectorint,allocator vec(ia,ia+12);

sort(ia,ia+12);

int *iter = upper_bound(ia,ia+12,19);

assert( *iter == 20 );

sort( vec.begin(), vec.end(), greaterint() );

vectorint,allocator::iterator iter_vec;

iter_vec = upper_bound( vec.begin(), vec.end(),

27, greaterint() );

assert( *iter_vec == 26 );

// печатается: 51 40 35 29 27 26 23 22 20 19 17 15 12

vec.insert( iter_vec, 27 );

for_each( vec.begin(), vec.end(), pfi ); cout " ";

}