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.参数
| first, last | - | |
| comp | - | 比较函数对象(即满足比较 (Compare) 要求的对象),如果首个实参小于 第二个,则返回 true。比较函数的签名应等价于如下:
虽然签名不必有 |
| 类型要求 | ||
返回值
复杂度
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
另请参阅
| 复制范围中元素并部分排序 (函数模板) | |
| 将范围中元素排序,同时保持相等元之间的顺序 (函数模板) | |
| 将范围按升序排序 (函数模板) |