std::nth_element
From Cppreference
Defined in header
<algorithm> | ||
template< class RandomAccessIterator >
void nth_element( RandomAccessIterator first, | (1) | |
template< class RandomAccessIterator, class Compare >
void nth_element( RandomAccessIterator first, | (2) | |
Partially sorts the range [first, last) in ascending order so that all elements in the range [first, nth) are less than those in the range [nth, last). The first version uses operator< to compare the elements, the second version uses the given comparison function comp.
Contents |
Parameters
first, last | - | random access iterators defining the range sort | |||||||||
nth | - | random access iterator defining the sort partition point | |||||||||
comp | - | comparison function which returns true if the first argument is less than the second. The signature of the comparison function should be equivalent to the following:
The signature does not need to have const &, but the function must not modify the objects passed to it. |
Return value
(none)
Complexity
Linear in std::distance(first, last) on average.
Example
This section is incomplete |
See also
| copies and partially sorts a range of elements (function template) | |
| sorts a range of elements while preserving order between equal elements (function template) | |
| sorts a range into ascending order (function template) |