• C++11标准模板(STL)- 算法(std::partial_sort)


    定义于头文件 

    算法库提供大量用途的函数(例如查找、排序、计数、操作),它们在元素范围上操作。注意范围定义为 [first, last) ,其中 last 指代要查询或修改的最后元素的后一个元素。

    排序一个范围的前 N 个元素

    std::partial_sort

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

    (1)(C++20 前)

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

    (C++20 起)
    template< class ExecutionPolicy, class RandomIt >

    void partial_sort( ExecutionPolicy&& policy,

                       RandomIt first, RandomIt middle, RandomIt last );
    (2)(C++17 起)
    template< class RandomIt, class Compare >

    void partial_sort( RandomIt first, RandomIt middle, RandomIt last,

                       Compare comp );
    (3)(C++20 前)
    template< class RandomIt, class Compare >

    constexpr void partial_sort( RandomIt first, RandomIt middle, RandomIt last,

                                 Compare comp );
    (C++20 起)
    template< class ExecutionPolicy, class RandomIt, class Compare >

    void partial_sort( ExecutionPolicy&& policy,
                       RandomIt first, RandomIt middle, RandomIt last,

                       Compare comp );
    (4)(C++17 起)

    重排元素,使得范围 [first, middle) 含有范围 [first, last) 中已排序的 middle - first 个最小元素。

    不保证保持相等的元素顺序。范围 [middle, last) 中剩余的元素顺序未指定。

    1) 用 operator< 比较元素。

    3) 用给定的二元比较函数 comp 比较元素。

    2,4) 同 (1,3) ,但按照 policy 执行。这些重载仅若 std::is_execution_policy_v> 为 true 才参与重载决议。

    参数

    first, last-定义范围的随机访问迭代器
    middle-定义要排序的末元素的随机访问迭代器
    policy-所用的执行策略。细节见执行策略。
    comp-比较函数对象(即满足比较 (Compare) 概念的对象),若第一参数小于(即序于)第二参数则返回 ​true 。

    比较函数的签名应等价于如下:

     bool cmp(const Type1 &a, const Type2 &b);

    虽然签名不必有 const & ,函数也不能修改传递给它的对象,而且必须接受(可为 const 的)类型 Type1Type2 的值,无关乎值类别(从而不允许 Type1 & ,亦不允许 Type1 ,除非 Type1 的移动等价于复制 (C++11 起))。
    类型 Type1 与 Type2 必须使得 RandomIt 类型的对象能在解引用后隐式转换到这两个类型。 ​

    类型要求
    - RandomIt 必须满足值可交换 (ValueSwappable) 和 遗留随机访问迭代器 (LegacyRandomAccessIterator) 的要求。
    - 解引用 RandomIt 结果的类型必须满足可移动赋值 (MoveAssignable) 和可移动构造 (MoveConstructible) 的要求。

    返回值

    (无)

    复杂度

    约 (last-first)log(middle-first) 次应用 cmp

    异常

    拥有名为 ExecutionPolicy 的模板形参的重载按下列方式报告错误:

    • 若作为算法一部分调用的函数的执行抛出异常,且 ExecutionPolicy 为标准策略之一,则调用 std::terminate 。对于任何其他 ExecutionPolicy ,行为是实现定义的。
    • 若算法无法分配内存,则抛出 std::bad_alloc 。

    调用示例

    1. #include <iostream>
    2. #include <algorithm>
    3. #include <functional>
    4. #include <vector>
    5. #include <iterator>
    6. #include <time.h>
    7. using namespace std;
    8. struct Cell
    9. {
    10. int x;
    11. int y;
    12. Cell &operator +=(const Cell &cell)
    13. {
    14. x += cell.x;
    15. y += cell.y;
    16. return *this;
    17. }
    18. bool operator <(const Cell &cell) const
    19. {
    20. if (x == cell.x)
    21. {
    22. return y < cell.y;
    23. }
    24. else
    25. {
    26. return x < cell.x;
    27. }
    28. }
    29. };
    30. std::ostream &operator<<(std::ostream &os, const Cell &cell)
    31. {
    32. os << "{" << cell.x << "," << cell.y << "}";
    33. return os;
    34. }
    35. int main()
    36. {
    37. srand((unsigned)time(NULL));;
    38. std::cout.setf(std::ios_base::boolalpha);
    39. auto func1 = []()
    40. {
    41. int n = std::rand() % 10 + 100;
    42. Cell cell{n, n};
    43. return cell;
    44. };
    45. vector<Cell> cells(8);
    46. std::generate(cells.begin(), cells.end(), func1);
    47. std::cout << "cells : ";
    48. std::copy(cells.begin(), cells.end(), std::ostream_iterator<Cell>(std::cout, " "));
    49. std::cout << std::endl;
    50. std::cout << "is_sorted: " << std::is_sorted(cells.begin(), cells.end());
    51. std::cout << std::endl << std::endl;
    52. std::partial_sort(cells.begin(), cells.begin() + 5, cells.end());
    53. std::cout << "cells partial_sort : ";
    54. std::copy(cells.begin(), cells.end(), std::ostream_iterator<Cell>(std::cout, " "));
    55. std::cout << std::endl;
    56. std::cout << "is_sorted: " << std::is_sorted(cells.begin(), cells.begin() + 5);
    57. std::cout << std::endl << std::endl;
    58. auto is_sortf = [](const Cell & a, const Cell & b)
    59. {
    60. if (a.x == b.x)
    61. {
    62. return a.y > b.y;
    63. }
    64. return a.x > b.x;
    65. };
    66. std::generate(cells.begin(), cells.end(), func1);
    67. std::cout << "cells : ";
    68. std::copy(cells.begin(), cells.end(), std::ostream_iterator<Cell>(std::cout, " "));
    69. std::cout << std::endl;
    70. std::cout << "is_sorted: " << std::is_sorted(cells.begin(), cells.end(), is_sortf);
    71. std::cout << std::endl << std::endl;
    72. std::partial_sort(cells.begin(), cells.begin() + 5, cells.end(), is_sortf);
    73. std::cout << "cells partial_sort : ";
    74. std::copy(cells.begin(), cells.end(), std::ostream_iterator<Cell>(std::cout, " "));
    75. std::cout << std::endl;
    76. std::cout << "is_sorted: " << std::is_sorted(cells.begin(), cells.begin() + 5, is_sortf);
    77. std::cout << std::endl << std::endl;
    78. return 0;
    79. }

    输出

  • 相关阅读:
    线性插值方法
    AT89S52单片机
    Maven 私服 Nexus3
    C#中的数组探究与学习
    数据结构 ----- 折半插入排序
    AOP(JDK动态代理实现)
    二叉搜索树
    opencv交互式调整视觉算法参数(一)-图像阈值参数
    新需求:实现一个自动运维部署工具
    《软件质量保证与测试》第 6 章——系统测试 重点部分总结
  • 原文地址:https://blog.csdn.net/qq_40788199/article/details/127895154