一、简介
原 型: void qsort(void *base, int nelem, int width, int (*fcmp)(const void *,const void *));
功 能: 使用快速排序例程进行排序
参 数:1 待排序数组首地址 2 数组中待排序元素数量 3 各元素的占用空间大小 4 指向函数的指针,用于确定排序的顺序
说明:qsort函数是ANSI C标准中提供的,其声明在stdlib.h文件中,是根据二分法写的,其时间复杂度为n*log(n)。
qsort要求提供的函数是需要自己定义的一个比较函数,比较函数使得qsort通用性更好。有了比较函数qsort可以实现对数组、字符串、结构体等结构进行升序或降序排序。
如int cmp(const void *a, const void *b)中有两个元素作为参数,返回一个int值,如果比较函数返回大于0,qsort就认为a > b,返回小于0qsort就认为a <
b。qsort知道元素的大小了,就可以把大的放前面去。如果你的比较函数返回本来应该是1的(即a > b),而却返回-1(小于0的数),那么qsort认为a < b,就把b放在前面去,但实际上是a > b的,所以就造成了降序排序的差别了。
简单来说,比较函数的作用就是给qsort指明元素的大小事怎么比较的。
二、使用举例(MinGW5测试通过)
1、对一维数组排序:
2、对字符串排序:
04 | typedef char Element_type; |
06 | Element_type list[] = "djfkwjefklwefagj" ; |
08 | int Comp( const void *p1, const void *p2) |
11 | return strcmp (( char *)p2,( char *)p1); |
13 | //return strcmp((char *)p1,(char *)p2); |
22 | //考虑还有字符串结束符,这里元素个数别忘减1 |
23 | qsort (list, sizeof (list) / sizeof (Element_type) - 1, sizeof (Element_type), Comp); |
3、按结构体中某个关键字排序(对结构体一级排序):
10 | int Comp( const void *p1, const void *p2) |
12 | return (*(Node *)p2)->data - (*(Node *)p1)->data; |
21 | qsort (s, 100, sizeof (s[0]), Comp); |
4、按结构体中多个关键字排序(对结构体多级排序)[以二级为例]:
5 | }s[100]; //按照x从小到大排序,当x相等时按y从大到小排序 |
1 | int Comp( const void *p1, const void *p2) |
3 | struct Node *c = (Node *)p1; |
4 | struct Node *d = (Node *)p2; |
6 |
if (c->x != d->x) return c->x - d->x; |
7 | else return d->y - c->y; |
5、对结构体中字符串进行排序:
08 | int Comp( const void *p1, const void *p2) |
10 | return strcmp ((*(Node *)p1)->str,(*(Node *)p2)->str); |