2026年2月8日学习总结:
本次学习主要围绕qsort函数展开,进阶的指针也接近尾声,本次学习主要分为以下两个部分:
1.用qsort函数对结构体进行排序:
在了解qsort函数的时候我们知道它可以排序任意数据,在之前我们只是对整型进行排序了,现在我们对结构体进行排序。
代码如下:
cs
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
struct stu
{
char name[20];
int age;
};
int cmp_stu_name(const void* e1, const void* e2)
{
return strcmp(((char*)e1), ((char*)e2));
}
int cmp_stu_age(const void* e1, const void* e2)
{
return *(int*)e1 - *(int*)e2;
}
void test()
{
struct stu arr[3] = { {"zhangsan",15},{"lisi",30},{"wangwu",25} };
int sz = sizeof(arr) / sizeof(arr[0]);
//qsort(arr, sz, sizeof(arr[0]), cmp_stu_name);
qsort(arr, sz, sizeof(arr[0]), cmp_stu_age);
int i = 0;
for (i = 0; i < 3; i++)
{
printf("%s %d\n", arr[i].name,arr[i].age);
}
printf("\n");
}
int main()
{
test();
return 0;
}
在该代码中,首先创建一个包含姓名、年龄的结构体,在使用qsort函数分别进行排序,对姓名排序时使用strcmp函数进行排序,而年龄用指针强制转换进行排序,最后分别将内容进行打印查看结果。
注意:strcmp函数需包含string.h头文件;qsort函数需包含stdlib.h头文件。
2.模拟写my_qsort函数
既然我们已经了解了qsort函数的基本内容,现在以冒泡排序为基础写出my_qsort函数。代码如下:
cs
void swap(char* buf1, char* buf2, int sz)
{
int i = 0;
for (i = 0; i < sz; i++)
{
char tmp = *buf1;
*buf1 = *buf2;
*buf2 = tmp;
buf1++;
buf2++;
}
}
void my_qsort(void* base, int num, int width, int (*cmp)(const void* e1, const void* e2))
{
int i = 0;
//趟数
for (i = 0; i < num - 1; i++)
{
int flag = 1; //假设数组是排好序的
//一趟冒泡排序的过程
int j = 0;
for (j = 0; j < num - i - 1; j++)
{
if (cmp((char*)base + j * width, (char*)base + (j + 1) * width)>0)
{
//交换
swap((char*)base + j * width, (char*)base + (j + 1) * width, width);
flag = 0;
}
}
if (flag == 1)
{
break;
}
}
}
在冒泡排序的代码的基础上修改,唯一不同的地方就是在内循环中进行比较的代码,将相关值改成改成函数的相关参数,在使用比较函数时用最开始的函数值base转换成char*类型后加上移动的j和宽度值width的乘积,与此对比的(j+1)的元素也是同样乘上宽度值width。判断cmp函数的返回值,然后通过swap函数进行交换。
写完该函数可以通相关代码进行测试。