C++ sort

想到之前面试官问我,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/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • STL里面有个sort函数,可以直接对数组排序,复杂度为n*log2(n)。使用这个函数,需要包含头文件。 这个函...
    cincinw阅读 235评论 0 0
  • 1. 普通排序 利用sort函数中的compare参数 第一个参数first:是要排序的数组的起始地址。第二个参数...
    Mine4ever_阅读 1,824评论 0 0
  • 说明 nth_element(first, nth, last) nth_element是把第n个元素放在第n个...
    book_02阅读 1,525评论 0 1
  • 仅用于记录平时学习的心得,经常更新 迭代器 iterator优先于const_iterator,reverse_i...
    this_is_for_u阅读 1,181评论 0 0
  • sort(s.begin(),s.end(),less) 第三个参数可以不写,默认是升序。也可以用函数指针或者函数...
    元素周期表的十七君阅读 566评论 0 0

友情链接更多精彩内容