方法一:qsort
#include <stdlib.h>
void qsort(void* base,
size_t num,
size_t size,
int (*cmp)(const void* e1, const void* e2)
)
代码展示
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void print_arr(int arr[], int sz)
{
for (int i = 0; i < sz; i ++)
printf("%d ", arr[i]);
printf("\n");
}
int cmp_int(const void* e1, const void* e2)
{
return *(int*)e1 - *(int*)e2;
}
void test1()
{
int arr[] = {9, 8, 7, 6, 5, 4, 3, 2, 1, 0};
int sz = sizeof(arr) / sizeof(arr[0]);
qsort(arr, sz, sizeof(arr[0]), cmp_int);
print_arr(arr, sz);
}
struct stu
{
char name[20];
int age;
};
int sort_by_age(const void* e1, const void* e2)
{
return ((struct stu*)e1)->age - ((struct stu*)e2)->age;
}
int sort_by_name(const void* e1, const void* e2)
{
return strcmp(((struct stu*)e1)->name , ((struct stu*)e2)->name);
}
void test2()
{
struct stu s[3] = {{"zhangsan", 30},{"lisi", 34} ,{"wangwu", 20} };
int sz = sizeof(s) / sizeof(s[0]);
qsort(s, sz, sizeof(s[0]), sort_by_age);
qsort(s, sz, sizeof(s[0]), sort_by_name);
for (int i = 0; i < sz; i ++)
printf("%s ", s[i]);
}
int main()
{
test1();
test2();
return 0;
}