void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )(const void *elem1, const void *elem2 ) );
需要自行编写比较函数
针对不同类型的比较函数
int cmp_int(int* e1,int* e2)
{
return *e1 - *e2;
}
int cmp_str(char** e1, char** e2)
{
return strcmp(*e1,*e2);
}
int cmp_char(char* e1, char* e2)
{
return -(*e1 - *e2);
}
int cmp_float(float* e1, float* e2)
{
if (*e1 - *e2 > 10E-6)
return 1;
else if (*e1 - *e2 < 0)
return -1;
else return 0;
}
如果是.c文件的化,这样写比较函数是没有任何问题的,只是会有警告,cpp文件就会编译不过
直接报错,c++对于类型检查更严格
#include<stdio.h>
#include<stdlib.h>
int cmp(const void *e1, const void* e2)
{
return *(int*)e1 - *(int*)e2;//指针类型强转,后解引用
}
int cmp1(int*e1, int*e2)//.C文件才可以
{
return *e1 - *e2;
}
int main()
{
int a[] = { 435, 21, 12, 6, 21, 8, 1, 984 };
int n = sizeof(a) / sizeof(a[0]);
qsort(a, n,4, cmp);
return 0;
}