std:: is_partitioned
|
Определено в заголовочном файле
<algorithm>
|
||
|
template
<
class
InputIt,
class
UnaryPred
>
bool is_partitioned ( InputIt first, InputIt last, UnaryPred p ) ; |
(1) |
(начиная с C++11)
(constexpr начиная с C++20) |
|
template
<
class
ExecutionPolicy,
class
ForwardIt,
class
UnaryPred
>
bool
is_partitioned
(
ExecutionPolicy
&&
policy,
|
(2) | (начиная с C++17) |
[
first
,
last
)
предикатом
p
: все элементы, удовлетворяющие
p
, расположены перед элементами, которые не удовлетворяют.
|
std:: is_execution_policy_v < std:: decay_t < ExecutionPolicy >> равно true . |
(до C++20) |
|
std:: is_execution_policy_v < std:: remove_cvref_t < ExecutionPolicy >> равно true . |
(начиная с C++20) |
Содержание |
Параметры
| first, last | - | пара итераторов, определяющих диапазон элементов для проверки |
| policy | - | политика выполнения для использования |
| p | - |
унарный предикат, который возвращает
true
для элементов, ожидаемых в начале диапазона.
Выражение
p
(
v
)
должно быть преобразуемо в
bool
для каждого аргумента
|
| Требования к типам | ||
-
InputIt
должен удовлетворять требованиям
LegacyInputIterator
.
|
||
-
ForwardIt
должен удовлетворять требованиям
LegacyForwardIterator
, и его тип значения должен быть преобразуем в тип параметра
UnaryPred
.
|
||
-
UnaryPred
должен удовлетворять требованиям
Predicate
.
|
||
Возвращаемое значение
true
если элементы
e
из диапазона
[
first
,
last
)
являются
разделёнными
относительно выражения
p
(
e
)
.
false
в противном случае.
Сложность
Не более std:: distance ( first, last ) применений p .
Исключения
Перегрузка с параметром шаблона с именем
ExecutionPolicy
сообщает об ошибках следующим образом:
-
Если выполнение функции, вызванной как часть алгоритма, выбрасывает исключение и
ExecutionPolicyявляется одним из стандартных политик , std::terminate вызывается. Для любой другойExecutionPolicyповедение определяется реализацией. - Если алгоритму не удается выделить память, std::bad_alloc выбрасывается.
Возможная реализация
template<class InputIt, class UnaryPred> bool is_partitioned(InputIt first, InputIt last, UnaryPred p) { for (; first != last; ++first) if (!p(*first)) break; for (; first != last; ++first) if (p(*first)) return false; return true; } |
Пример
#include <algorithm> #include <array> #include <iostream> int main() { std::array<int, 9> v {1, 2, 3, 4, 5, 6, 7, 8, 9}; auto is_even = [](int i) { return i % 2 == 0; }; std::cout.setf(std::ios_base::boolalpha); std::cout << std::is_partitioned(v.begin(), v.end(), is_even) << ' '; std::partition(v.begin(), v.end(), is_even); std::cout << std::is_partitioned(v.begin(), v.end(), is_even) << ' '; std::reverse(v.begin(), v.end()); std::cout << std::is_partitioned(v.cbegin(), v.cend(), is_even) << ' '; std::cout << std::is_partitioned(v.crbegin(), v.crend(), is_even) << '\n'; }
Вывод:
false true false true
Смотрите также
|
делит диапазон элементов на две группы
(шаблон функции) |
|
|
(C++11)
|
находит точку разделения в разделённом диапазоне
(шаблон функции) |
|
(C++20)
|
определяет, разделён ли диапазон заданным предикатом
(функциональный объект алгоритма) |