首先,我们来谈谈大名鼎鼎的void qsort(void *base,int nelem,int width,int (*fcmp)(const void *,const void *));
它属于C语言标准库函数,应该是运用最多的了,今天我不是来教你们怎么用qsort的,只是来交流一下排序函数的最后一个参数cmp()(它不仅可以叫cmp,你还可以给他取名叫什么pig啊dog的只要是英文单词都可以,cmp只是人们对compare的一种常用缩写)比较函数的写法。
下面是cmp的写法:
int cmp(const void *a ,const void *b)
{
return *(int *)a - *(int *)b ; //从小到大排序,把a,b位置反过来就是从大到小
}
注意:qsort的cmp()函数千万别写成下面这样
//错错错错错错错 错错错错错错错 错错错错错错错 错错错错错错错
int cmp(con void *a ,const void *b)
{
return *(int *)a > *(int *)b ; // > 与 < 都不行 !
}
//XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
#include <stdio.h>
#include <stdlib.h>
int cmp(const void *a ,const void *b)
{
return *(int *)a - *(int *)b ; //从小到大排序,把a,b位置反过来就是从大到小
}
int main()
{
int a[10]={-1,9,5,7,-11,2,6,8,9,6};
qsort(a,10,sizeof(int),cmp);
for(int i = 0 ; i < 10 ; ++i)
{
printf("%d ",a[i]);
}
printf("\n") ;
return 0 ;
}
http://blog.csdn.net/lionel_d/article/details/41746135