sort(first_pointer,first_pointer+n,cmp)
该函数可以给数组,或者链表list、向量排序。
实现原理:sort并不是简单的快速排序,它对普通的快速排序进行了优化,此外,它还结合了插入排序和推排序。系统会根据你的数据形式和数据量自动选择合适的排序方法,这并不是说它每次排序只选择一种方法,它是在一次完整排序中不同的情况选用不同方法,比如给一个数据量较大的数组排序,开始采用快速排序,分段递归,分段之后每一段的数据量达到一个较小值后它就不继续往下递归,而是选择插入排序,如果递归的太深,他会选择推排序。
此函数有3个参数:
参数1:第一个参数是数组的首地址,一般写上数组名就可以,因为数组名是一个指针常量。
参数2:第二个参数相对较好理解,即首地址加上数组的长度n(代表尾地址的下一地址)。
参数3:默认可以不填,如果不填sort会默认按数组升序排序。也就是1,2,3,4排序。也可以自定义一个排序函数,改排序方式为降序什么的,也就是4,3,2,1这样。
使用此函数需先包含:
#include
using namespace std;简单例子:对数组A的0~n-1元素进行升序排序,只要写sort(A,A+n)即可;对于向量V也一样,sort(v.begin(),v.end())即可。
自己编写排序规则函数
例如:bool compare(int a,int b){ return ab,则为降序 }sort扩展
sort不只是能像上面那样简单的使用,我们可以对sort进行扩展,关键就在于第三个参数
方法一:定义比较函数(最常用)//情况一:数组排列int A[100];bool cmp1(int a,int b)//int为数组数据类型{ return a>b;//降序排列 //return ab.id;//按照学号降序排列 //return a.id 方法二:使用标准库函数 另外,其实我们还可以再懒一点,在标准库中已经有现成的。它在哪呢?答案是functional,我们include进来试试看。functional提供了一堆基于模板的比较函数对象,它们是:equal_to ● 升序:sort(begin,end,less ● 降序:sort(begin,end,greater 缺点:也只是实现简单的排序,结构体不适用。 #include //情况一:在结构体内部重载typedef struct Student{ int id; string name; double grade; bool operator<(const Student& s) { return id>s.id;//降序排列 //return id 方法四:声明比较类(少用) struct Less{ bool operator()(const Student& s1, const Student& s2) { return s1.id #include "stdafx.h"#include 参考文献:https://www.cnblogs.com/luorende/p/6121906.html--------------------- #include