sort()函数与qsort()函数
qsort()函数与sort()函数简记
qsort函数和sort函数只能对连续内存上的数据进行排序。
一 qsort()函数
qsort(基本快速排序的方法,每次把数组分成两部分和中间的一个划分值,而对于有多个重复值的数组来说,基本快速排序的效率较低,且不稳定)。集成在C语言库函数里面的的qsort函数,使用三路划分的方法解决排序这个问题。所谓三路划分,是指把数组划分成小于划分值,等于划分值和大于划分值的三个部分。
qsort()函数的具体形式
void qsort( void base, size_t num, size_t width, int (__cdecl *compare )
int compare (const void *elem1, const void *elem2 ) );
qsort(即,quicksort)主要根据你给的比较条件给一个快速排序,主要是通过指针移动实现排序功能。排序之后的结果仍然放在原来数组中。
参数意义如下:
第一个参数base是需要排序的目标数组名(或者也可以理解成开始排序的地址,因为可以写&s[i]这样的表达式)
第二个参数nu 是参与排序的目标数组元素个数
第三个参数width是单个元素的大小(或者目标数组中每一个元素长度),推荐使用sizeof(s[0])这样的表达式
第四个参数 compare 就是让很多人觉得非常困惑的比较函数啦。
比较函数compare()返回值必须是int,两个参数必须都是const void *,至于参数名称就按喜好来写即可。
*qsort()函数的使用方法**
1.对int型数组进行排序
int num[10]; int cmp(const void *a,const void *b) { return *(int*)a-*(int*)b; //升序排序 //return *(int*)b-*(int*)a; //降序排序 } qsort(num,10,sizeof(num[0]),cmp);
可见:比较函数cmp的参数列表是两个空指针,要强制转换到当前的数据类型,然后进行取值操作。升序排序时,若第一个参数指针指向的“值”大于第二个参数指针指向的“值”,则返回一个正数;若第一个参数指针指向的“值”等于第二个参数指针指向的“值”,则返回零;若第一个参数指针指向的“值”小于第二个参数指针指向的“值”,则返回负数。降序排序时刚好相反。
2.对char类型数组排序(同int类型数组)
char word[10]; int cmp(const void *a,const void *b) { return *(char*)a-*(char*)b; //升序排序 //return *(char*)a-*(char*)b; 降序排序 } qsort(word,10,sizeof(word[0]),cmp);
3.对double类型数组排序(特别要注意两个double型数据相减返回的整数可能是0,故要使用判断语句进行返回)
double data[10]; int cmp(const void *a,const void *b) { return *(double*)a>*(double*)b; } qsort(data,10,sizeof(data[0]),cmp);
4.对结构体一级排序
struct data { double d; int i; }num[10]; int cmp(const void *a,const void *b) { return (*(data*)a).d>(*(data*)b).d; } qsort(num,10,sizeof(num[0]),cmp);
5.对结构体二级排序
struct data { int x; int y; }num[10]; //按照x从小到大进行排序,当x相等时按照y从大到小进行排序 int cmp(const void *a,const void *b) { data *ta=(data*)a; data *tb=(data*)b; if(ta->x==tb->x) return tb->y-ta->y; else return ta->x-tb->x; } qsort(num,10,sizeof(num[0]),cmp);
6.对字符串进行排序
string s[10]; int cmp(const void *a,const void *b) { return *(string*)a>*(string*)b; } qsort(s,10,sizeof(s[0]),cmp);
注意:使用qsort()函数进行排序时,得自己写比较函数!!
二 sort()函数
使用sort()函数时,得包含头文件#include<algorithm>和命名空间std
std::sort是一个改进版的qsort. std::sort函数优于qsort的一些特点:对大数组采取9项取样,更完全的三路划分算法,更细致的对不同数组大小采用不同方法排序。</algorithm>
sort()函数和qsort()函数的区别
sort是qsort的升级版,如果能用sort尽量用sort,使用也比较简单,不像qsort还得自己去写 cmp 函数,只要注明使用的库函数就可以使用,参数只有两个(如果是普通用法)头指针和尾指针;qsort()函数要求提供的函数是需要自己定义的一个比较函数,比较函数使得qsort()通用性更好。有了比较函数qsort()可以实现对数组、字符串、结构体等结构进行升序或降序排序。但是sort()函数比qsort()函数更加高效。
qsort()函数的比较函数:
int cmp(const void *a, const void *b)
{
...
}
cmp()会有三种返回值(以qsort为例):
1、返回一个正数:a排列在b之后;
2、返回0:a、b相等;
3、返回一个负数:a排在b之前;
sort()函数的比较函数:
bool cmp(int a,int b)
{
...
}
1、返回true(或者1),a排列在b前面
2、返回false(或者0),a排在b后面
默认sort排序后是升序,如果想让他降序排列,可以使用自己编的cmp函数