std::partial_sort
From Cppreference
Defined in header
<algorithm> | ||
template< class RandomAccessIterator >
void partial_sort( RandomAccessIterator first, | (1) | |
template< class RandomAccessIterator, class Compare >
void partial_sort( RandomAccessIterator first, | (2) | |
Sorts some of the elements in the range [first, last) in ascending order. The first middle - first of these elements are placed in the range [first, middle). The order of equal elements is guaranteed to be preserved. The order of the remaining elements in the range [middle, last) is unspecified. The first version uses operator< to compare the elements, the second version uses the given comparison function comp.
Contents |
Parameters
first, last | - | the range of elements to sort | |||||||||
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
O(N*log2(N)), where N = std::distance(first, last) applications of cmp. If additional memory is available, then the complexity is O(N*log(N))
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) |