C++ sort

作者: 吃掉夏天的怪物 | 来源:发表于2021-05-19 21:45 被阅读0次

想到之前面试官问我,sort用了什么排序方法,我还憨憨的想...不就是快排吗...
今天才看到这篇文章。
sort 包含了,快排、插入、堆排序。

https://www.cnblogs.com/stones-dream/p/10183210.html
sort(first_pointer,first_pointer+n,cmp)
该函数可以给数组,或者链表list、向量排序。

实现原理:sort并不是简单的快速排序,它对普通的快速排序进行了优化,此外,它还结合了插入排序和推排序。系统会根据你的数据形式和数据量自动选择合适的排序方法,这并不是说它每次排序只选择一种方法,它是在一次完整排序中不同的情况选用不同方法,比如给一个数据量较大的数组排序,开始采用快速排序,分段递归,分段之后每一段的数据量达到一个较小值后它就不继续往下递归,而是选择插入排序,如果递归的太深,他会选择推排序。

此函数有3个参数:
参数1:第一个参数是数组的首地址,一般写上数组名就可以,因为数组名是一个指针常量。
参数2:第二个参数相对较好理解,即首地址加上数组的长度n(代表尾地址的下一地址)。
参数3:默认可以不填,如果不填sort会默认按数组升序排序。也就是1,2,3,4排序。也可以自定义一个排序函数,改排序方式为降序什么的,也就是4,3,2,1这样。
使用此函数需先包含:
#include <algorithm>
并且导出命名空间:
using namespace std;
简单例子:对数组A的0~n-1元素进行升序排序,只要写sort(A,A+n)即可;对于向量V也一样,sort(v.begin(),v.end())即可。
自己编写排序规则函数
例如:

bool compare(int a,int b)
{
return a<b; //升序排列,如果改为return a>b,则为降序
}

另外,c++中提供了比较函数,就不需要我们来重新写比较函数了

less<type>()    //从小到大排序 <
grater<type>()  //从大到小排序 >
less_equal<type>()  //  <=
gtater_equal<type>()//  >=
//这四种函数

小零碎

做leetcode发现这个函数之前没有用过
C++ nth_element(STL nth_element)排序

nth_element() 算法和 partial_sort() 不同。应用的范围由它的第一个和第三个参数指定。第二个参数是一个指向第 n 个元素的迭代器。如果这个范围内的元素是完全有序的,nth_dement() 的执行会导致第 n 个元素被放置在适当的位置。这个范围内,在第 n 个元素之前的元素都小于第 n 个元素,而且它后面的每个元素都会比它大。算法默认用 < 运算符来生成这个结果。
nth_element(results.begin(), results.begin() + k - 1, results.end(), greater<int>());

https://leetcode-cn.com/problems/find-kth-largest-xor-coordinate-value/solution/zhao-chu-di-k-da-de-yi-huo-zuo-biao-zhi-mgick/

相关文章

  • 2022-03-20【ue】TArray.Sort&Find:L

    Sort c++ - 'content' is not captured - Arduino Stack Exch...

  • std::sort coredump 说起

    @(c++) core 的原因 c++ 标准库 sort() 默认采用 < 这个 operator 来排序的, 另...

  • C++ sort

    想到之前面试官问我,sort用了什么排序方法,我还憨憨的想...不就是快排吗...今天才看到这篇文章。sort 包...

  • 一些函数

    cmp函数 C++ sort cmp函数 - lzz的博客 - CSDN博客 浅谈C/C++排序函数中cmp()比...

  • Merge k Sorted Lists

    标签: C++ 算法 LeetCode 链表 每日算法——leetcode系列 问题 Merge Two Sort...

  • Sort函数

    目的:通过了解Sort函数的实现过程,复习学过的快排,堆排,插入排序。 Sort函数是C++自带的库函数。需要头文...

  • sort用法(转)

    一、c++标准库里的排序函数的使用方法 ​I)Sort函数包含在头文件为#include的c++标准库中 II)S...

  • 383. Ransom Note

    C++ Java Javascript 注意这里各种语言sort的方法和string化数组方法 最优解 Java,...

  • C++排序函数sort()

    最近在刷PAT题库时遇到这样一个题宋代史学家司马光在《资治通鉴》中有一段著名的“德才论”:“是故才德全尽谓之圣人,...

  • C++ sort函数

    I)Sort函数包含在头文件为#include 的c++标准库中,调用标准库里的排序方法可以不必知道其内部是如何实...

网友评论

      本文标题:C++ sort

      本文链接:https://www.haomeiwen.com/subject/bmjmjltx.html