qsort是一个库函数,专门用来排序的,对与整形数据,结构体的可以进行排序.
为了使用qsort函数,我们需要了解这个函数的使用方法:
void qsort (void* base,//需要排序的首元素地址
size_t num, //指向base的元素数量
size_t size,//每个元素的大小(单位是字节)
int (*compar)(const void*,const void*));//用来比较创建的函数,返回值是函数指针类型,参数是void*
了解了这个函数,我们就可以来使用这个函数
#include<stdio.h>
#include<stdlib.h>//qsort库函数的头文件
int Judge_num(const void* p1, const void* p2)
{
return *(int*)p1 - *(int*)p2;//因为p1,p2是void*类型,所以就强制类型转换成int*类型,在解应用访问到对应元素
}
void print(int* arr, int sz)
{
int i = 0;
for (; i < sz; i++)
{
printf("%d ", *(arr + i));
}
}
void test2()
{
int arr[] = { 5,6,9,8,7,5,3,6,9,1,2,6};
int sz = sizeof(arr) / sizeof(arr[0]);
qsort(arr, sz, sizeof(arr[0]), Judge_num);
print(arr, sz);
}
int main()
{
test2();
return 0;
}