std::partial_sort
来自cppreference.com
|
|
该页由英文版维基使用谷歌翻译机器翻译而来。
该翻译可能存在错误或用词不当。鼠标停留在文本上可以看到原版本。你可以帮助我们修正错误或改进翻译。参见说明请点击此处。 |
<metanoindex/>
| 在标头 <algorithm> 定义
|
||
| |
(1) | |
| |
(2) | |
。排序部分中的元素按升序排列的范围
[first, last)。这些元素的第一middle - first被放置在的范围内[first, middle)。要保留相等元素的顺序是不能保证。的范围[middle, last)中剩余的元素的顺序是不确定的。 operator<的第一个版本使用比较的元素,第二个版本使用给定的比较函数comp.原文:
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 not 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.。参数。
Template:param list begin Template:param list item Template:param list cmp Template:param list hreq Template:param list req concept Template:param list req concept deref Template:param list end
===。 返回值。===
。复杂性。
。 O(N·log2(N)),
N = std::distance(first, last)应用cmp。如果需要额外的内存是可用的,那么复杂O(N·log(N))。。为例。
运行此代码
#include <algorithm>
#include <functional>
#include <array>
#include <iostream>
int main()
{
std::array<int, 10> s{5, 7, 4, 2, 8, 6, 1, 9, 0, 3};
std::partial_sort(s.begin(), s.begin() + 3, s.end());
for (int a : s) {
std::cout << a << " ";
}
}
输出:
0 1 2 7 8 6 5 9 4 3