function template
<algorithm>
std::partition
template <class BidirectionalIterator, class UnaryPredicate> BidirectionalIterator partition (BidirectionalIterator first, BidirectionalIterator last, UnaryPredicate pred);
template <class ForwardIterator, class UnaryPredicate> ForwardIterator partition (ForwardIterator first, ForwardIterator last, UnaryPredicate pred);
Partition range in two
[first,last), in such a way that all the elements for which pred returns true precede all those for which it returns false. The iterator returned points to the first element of the second group.The relative ordering within each group is not necessarily the same as before the call. See stable_partition for a function with a similar behavior but with stable ordering within each group.
The behavior of this function template (C++98) is equivalent to:
|
|
Parameters
- first, last
-
Bidirectional iterators to the initial and final positions of the sequence to partition. The range used is
[first,last), which contains all the elements between first and last1, including the element pointed by first but not the element pointed by last.
Forward iterators to the initial and final positions of the sequence to partition. The range used is
[first,last), which contains all the elements between first and last, including the element pointed by first but not the element pointed by last.
ForwardIterator shall point to a type for which swap is defined and swaps the value of its arguments.
- pred
- Unary function that accepts an element in the range as argument, and returns a value convertible to
bool. The value returned indicates whether the element is to be placed before (iftrue, it is placed before all the elements for which it returnsfalse).
The function shall not modify its argument.
This can either be a function pointer or a function object.
Return value
An iterator that points to the first element of the second group of elements (those for which pred returnsfalse), or last if this group is empty.Example
|
|
Possible output:
odd elements: 1 9 3 7 5 even elements: 6 4 8 2
Complexity
Linear in the distance between first and last: Applies pred to each element, and possibly swaps some of them (if the iterator type is a bidirectional, at most half that many swaps, otherwise at most that many).Data races
The objects in the range[first,last) are modified.Exceptions
Throws if either an element swap or an operation on an iterator throws.Note that invalid arguments cause undefined behavior.
See also
- reverse
- Reverse range (function template)
- rotate
- Rotate left the elements in range (function template)
- find_if
- Find element in range (function template)
- swap
- Exchange values of two objects (function template)