C语言进阶————指针4

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函数进行交换。

写完该函数可以通相关代码进行测试。

相关推荐
SuperByteMaster3 小时前
keil 工程 .gitignore配置文件
c语言
FQNmxDG4S3 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
前端老石人4 小时前
HTML 字符引用完全指南
开发语言·前端·html
matlab_xiaowang4 小时前
Redux 入门:JavaScript 可预测状态管理库
开发语言·javascript·其他·ecmascript
虹科网络安全4 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje4 小时前
Java语法进阶
java·开发语言·jvm
老前端的功夫5 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_435287925 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
止语Lab5 小时前
从手动到框架:Go DI 演进的三个拐点
开发语言·后端·golang
yaoxin5211235 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
java·开发语言·python