C 语言

关注公众号 jb51net

关闭
首页 > 软件编程 > C 语言 > C++ std::partial_sort

C++中std::partial_sort的使用小结

作者:点云SLAM

std::partial_sort 是 C++ 标准库中的一个算法,它可以对容器中的一部分元素进行排序,本文主要介绍了C++中std::partial_sort的使用小结,感兴趣的可以了解一下

std::partial_sort 是 C++ 标准库中的一个算法,它可以对容器中的一部分元素进行排序,使得前 N 个元素按顺序排列,而不保证剩余部分有序。它的时间复杂度为 O(N log N + (M-N)),其中 M 是整个范围的大小,N 是要排序的元素数量。

1. 语法

#include <algorithm>

template< class RandomIt >
void partial_sort( RandomIt first, RandomIt middle, RandomIt last );

template< class RandomIt, class Compare >
void partial_sort( RandomIt first, RandomIt middle, RandomIt last, Compare comp );

2. 基本用法

#include <iostream>
#include <vector>
#include <algorithm>

int main() {
    std::vector<int> vec = {7, 3, 9, 1, 6, 2, 8, 5, 4};

    // 仅对前 5 个元素排序
    std::partial_sort(vec.begin(), vec.begin() + 5, vec.end());

    // 输出前 5 个排序后的元素
    std::cout << "前 5 个最小的元素: ";
    for (int i = 0; i < 5; ++i) {
        std::cout << vec[i] << " ";
    }
    std::cout << "\n";

    // 输出整个数组
    std::cout << "整个数组: ";
    for (int num : vec) {
        std::cout << num << " ";
    }
    std::cout << "\n";

    return 0;
}

输出

前 5 个最小的元素: 1 2 3 4 5 
整个数组: 1 2 3 4 5 9 8 7 6 

注意:前 5 个元素是有序的,但整个数组仍然是部分无序的。

3. 使用自定义比较函数

可以使用 std::greater<int>() 进行降序排序:

#include <iostream>
#include <vector>
#include <algorithm>

int main() {
    std::vector<int> vec = {7, 3, 9, 1, 6, 2, 8, 5, 4};

    // 获取前 5 个最大的元素(降序)
    std::partial_sort(vec.begin(), vec.begin() + 5, vec.end(), std::greater<int>());

    // 输出前 5 个排序后的元素
    std::cout << "前 5 个最大的元素: ";
    for (int i = 0; i < 5; ++i) {
        std::cout << vec[i] << " ";
    }
    std::cout << "\n";

    return 0;
}

输出

前 5 个最大的元素: 9 8 7 6 5 

4. 与 std::sort 和 std::nth_element 的比较

算法作用复杂度适用场景
std::sort全部排序O(N log N)需要排序整个序列
std::partial_sort仅保证前 N 个元素有序O(N log N + (M-N))只需要最小/最大 N 个有序元素
std::nth_element只保证 N 处的元素正确,左侧比它小,右侧比它大O(M)只需要找到第 N 小的元素,且不关心其他元素顺序

5. 适用场景

到此这篇关于C++中std::partial_sort的使用小结的文章就介绍到这了,更多相关C++ std::partial_sort内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

您可能感兴趣的文章:
阅读全文