std::partial_sort

来自cppreference.com
TranslationBot留言 | 贡献2012年10月25日 (四) 20:00的版本 (Translated from the English version using Google Translate)
(差异) ←上一版本 | 最后版本 (差异) | 下一版本→ (差异)

<metanoindex/>

 
 
算法库
受约束算法及范围上的算法 (C++20)
包含算法例如 ranges::copy, ranges::sort, ...
执行策略 (C++17)
排序和相关操作
划分操作
排序操作
二分搜索操作(在已划分范围上)
集合操作(在有序范围上)
归并操作(在有序范围上)
堆操作
最小/最大操作
(C++11)
(C++17)
字典序比较操作
排列操作
C 库

数值运算
(C++11)                       
在未初始化内存上的操作
 
在标头 <algorithm> 定义
template< class RandomIt >
void partial_sort( RandomIt first, RandomIt middle, RandomIt last );
(1)
template< class RandomIt, class Compare >
void partial_sort( RandomIt first, RandomIt middle, RandomIt last, Compare comp );
(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

===。 返回值。===

。 (无)。
原文:
(none)
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

。复杂性。

O(N·log2(N))N = std::distance(first, last)应用cmp。如果需要额外的内存是可用的,那么复杂O(N·log(N))
原文:
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))
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

。为例。

#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

。另请参阅。

Template:cpp/algorithm/dcl list partial sort copyTemplate:cpp/algorithm/dcl list stable sortTemplate:cpp/algorithm/dcl list sort