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

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

相关推荐
祈安_3 天前
C语言内存函数
c语言·后端
郑州光合科技余经理4 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
feifeigo1234 天前
matlab画图工具
开发语言·matlab
dustcell.4 天前
haproxy七层代理
java·开发语言·前端
norlan_jame4 天前
C-PHY与D-PHY差异
c语言·开发语言
多恩Stone4 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
QQ4022054964 天前
Python+django+vue3预制菜半成品配菜平台
开发语言·python·django
czy87874754 天前
除了结构体之外,C语言中还有哪些其他方式可以模拟C++的面向对象编程特性
c语言
遥遥江上月4 天前
Node.js + Stagehand + Python 部署
开发语言·python·node.js
m0_531237174 天前
C语言-数组练习进阶
c语言·开发语言·算法