qsort函数是ANSIC标准中提供的,其声明在stdlib.h文件中,是根据二分法写的,其时间复杂度为n*log(n),其结构为:
voidqsort(void*base,size_tnelem,size_twidth,int(*Comp)(constvoid*,constvoid*));
其中:
*base为要排序的数组
nelem为要排序的数组的长度
width为数组元素的大小(以字节为单位)
默认是从小到大排序的!
qsort要求提供一个比较函数,是为了做到通用性更好一点。比较函数的作用就是给qsort指明元素的大小是怎么比较的。
像这样的比较函数intMyCmp(constvoid*a,constvoid*b)
都是有两个元素作为参数,返回一个int值,如果比较函数返回大于0,qsort就认为a>b;如果比较函数返回等于0,qsort就认为a=b;返回小于零qsort就认为a<b。
<本文中排序都是采用的从小到大排序>
一、对int类型数组排序
intnum[100];
Sample:
intcmp(constvoid*a,constvoid*b)
{
return*(int*)a-*(int*)b;//强制转换类型
}
qsort(num,100,sizeof(num[0]),cmp);
二、对char类型数组排序(同int类型)
charword[100];
Sample:
intcmp(constvoid*a,constvoid*b)
{
return*(char*)a-*(char*)b;
}
qsort(word,100,sizeof(word[0]),cmp);
三、对double类型数组排序(特别要注意)
doublein[100];
intcmp(constvoid*a,constvoid*b)
{
return*(double*)a>*(double*)b?1:-1;
}
qsort(in,100,sizeof(in[0]),cmp);
四、对结构体一级排序
structIn
{
doubledata;
intother;
}s[100];
//按照data的值从小到大将结构体排序,关于结构体内的排序关键数据data的类型可以很多种,参考上面的例子写
intcmp(constvoid*a,constvoid*b)
{
return(*(structIn*)a).data>(*(structIn*)b).data?1:-1;
}
qsort(s,100,sizeof(s[0]),cmp);
五、对结构体二级排序
structIn
{
intx;
inty;
}s[100];
//按照x从小到大排序,当x相等时按照y从大到小排序
intcmp(constvoid*a,constvoid*b)
{
structIn*c=(In*)a;
structIn*d=(In*)b;
if(c->x!=d->x)returnc->x-d->x;
elsereturnd->y-c->y;
}
qsort(s,100,sizeof(s[0]),cmp);
六、对字符串进行排序
structIn
{
intdata;
charstr[100];
}s[100];
//按照结构体中字符串str的字典顺序排序
intcmp(constvoid*a,constvoid*b)
{
returnstrcmp((*(structIn*)a)->str,(*(structIn*)b)->str);
}
qsort(s,100,sizeof(s[0]),cmp);
PS:其中的qsort函数包含在<stdlib.h>的头文件里