C++中sort()排序函数应用

**

C++中sort()排序函数应用

**
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;

升序排列(1 2 3 4):

升序排列时可省略第三个参数,默认为升序。

例如(此处定义数组a[4]={2,4,3,1}升序排列)

第一种表示方式(省略第三个参数代码):

#include 
#include
#include
using namespace std;

int main()
{
    int a[4]={2,4,3,1};
    sort(a,a+4);//此处省略了第三个参数
    for(int i=0;i<=3;i++)
        printf("%d",a[i]);
    return 0;
}

第二种表示方式(加参,自定义一个升序函数)

#include 
#include
#include
using namespace std;

bool com(int a,int b)
{
    return a<b;//升序排列函数
}

int main()
{
    int a[4]={2,4,3,1};
    sort(a,a+4,com);
    for(int i=0;i<=3;i++)
        printf("%d",a[i]);
    return 0;
}

输出结果:

1234

降序排列(4 3 2 1):

降序排列不可省略参数3,需要自定义一个降序函数

例如(排列数组a[4]={2,4,3,1})

#include 
#include
#include
using namespace std;

bool com(int a,int b)
{
    return a>b;//此处为降序排列函数
}

int main()
{
    int a[4]={2,4,3,1};
    sort(a,a+4,com);
    for(int i=0;i<=3;i++)
        printf("%d",a[i]);
    return 0;
}

输出结果:

4321

你可能感兴趣的:(笔记,算法)