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

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

相关推荐
badhope12 小时前
Mobile-Skills:移动端技能可视化的创新实践
开发语言·人工智能·git·智能手机·github
码云数智-园园13 小时前
微服务架构下的分布式事务:在一致性与可用性之间寻找平衡
开发语言
C++ 老炮儿的技术栈13 小时前
volatile使用场景
linux·服务器·c语言·开发语言·c++
hz_zhangrl13 小时前
CCF-GESP 等级考试 2026年3月认证C++一级真题解析
开发语言·c++·gesp·gesp2026年3月·gespc++一级
Liu6288813 小时前
C++中的工厂模式高级应用
开发语言·c++·算法
IT猿手14 小时前
基于控制障碍函数的多无人机编队动态避障控制方法研究,MATLAB代码
开发语言·matlab·无人机·openclaw·多无人机动态避障路径规划·无人机编队
AI科技星14 小时前
全尺度角速度统一:基于 v ≡ c 的纯推导与验证
c语言·开发语言·人工智能·opencv·算法·机器学习·数据挖掘
sunwenjian88614 小时前
Java进阶——IO 流
java·开发语言·python
波特率11520014 小时前
const关键字与函数的重载
开发语言·c++·函数重载
FL162386312914 小时前
[C#][winform]segment-anything分割万物部署onnx模型一键抠图演示
开发语言·c#