Сложность линейная (N + 1 сравнений) или (при нехватке памяти) N>*log N сравнений.
Возвращает true, если диапазон [first, last) представляет собой кучу (см. алгоритм make_heap). Для сравнения элементов используется предикат comp(>*p1, >*p2) или (по умолчанию) операция <.
Сложность линейная (не более N сравнений).
Определяет наибольший диапазон в пределах исходного диапазона [first, last), который начинается с first и представляет собой кучу (см. алгоритм make_heap). Возвращает позицию за концом найденного диапазона. Для сравнения элементов используется предикат comp(>*p1, >*p2) или (по умолчанию) операция <.
Сложность линейная (не более N сравнений).
Возвращает true, если в диапазоне [first, last) все элементы, удовлетворяющие предикату pred, расположены перед всеми элементами, которые предикату не удовлетворяют. В случае пустого диапазона также возвращается true.
Сложность линейная (не более N вызовов pred).
Возвращает true, если диапазон [first1, last1) представляет собой перестановку элементов диапазона, который начинается с first2 и имеет такую же длину. Для сравнения используется предикат pred(>*p1, >*p2) или (по умолчанию) операция ==.
Сложность: не более N>*N вызовов pred (ровно N вызовов в случае, если элементы первого диапазона совпадают с соответствующими элементами второго диапазона).
Возвращает true, если диапазон [first, last) представляет собой отсортированную последовательность. Для сравнения элементов используется предикат comp(>*p1, >*p2) или (по умолчанию) операция <.
Сложность линейная (не более N сравнений).
Определяет наибольший диапазон в пределах исходного диапазона [first, last), который начинается с first и представляет собой отсортированную последовательность. Возвращает позицию за концом найденного диапазона. Для сравнения элементов используется предикат comp(>*p1, >*p2) или (по умолчанию) операция <.
Сложность линейная (не более N сравнений).
Меняет местами значения, на которые указывают итераторы a и b.
Возвращает true, если последовательность [first1, last1) «меньше» (в лексикографическом смысле), чем последовательность [first2, last2), и false в противном случае (в частности, если последовательности равны, то возвращается false, а если первая последовательность является собственным префиксом второй, то возвращается true). Для сравнения элементов используется предикат comp(>*p1, >*p2) или (по умолчанию) операция <.
Сложность линейная (не более min{N>1, N>2} сравнений).
Проверяет, содержится ли в диапазоне [first, last) значение value, и возвращает итератор, который указывает на первое вхождение value (если значение не найдено, то итератор указывает на позицию в диапазоне, в которую можно вставить value, не нарушая порядка сортировки). Содержимое диапазона должно быть предварительно отсортировано в соответствии с порядком, задаваемым предикатом comp(>*p1, >*p2) или (по умолчанию) операцией <.
Сложность логарифмическая (не более log N + 1 сравнений).
Переупорядочивает элементы диапазона [first, last), получая из него кучу (т. е. очередь с приоритетом, для которой первый элемент всегда больше остальных, а добавление нового элемента или удаление первого элемента может быть произведено за логарифмическое время, и результат тоже будет кучей). Для сравнения элементов используется предикат comp(>*p1, >*p2) или (по умолчанию) операция <.
Сложность линейная (не более 3>*N сравнений).
Возвращает большее из значений a и b (при их равенстве возвращается a). Для сравнения значений используется предикат comp(a, b) или (по умолчанию) операция <.