库函数qsort的使用

news2025/1/11 17:45:42

在排序时,我们通常写的函数只能排一种固定的类型,那有没有一种方法可以用来对所有的数据类型,进行排序呢?库函数中的qsort函数就可以实现这种排序。
在这里插入图片描述
首先qsort的函数参数有四个,第一个是数组的起始地址(即数组名),第二个是数组的大小(元素个数),第三个是数组中一个元素的大小(占几个字节),第四个是函数指针(指向所要调用的函数且这个被调用的函数类型和形参与函数指针一致为int (const void* e1, const void* e2))。
先举个例子:

#include<stdio.h>
#include<stdlib.h>
//实现一个比较整型的函数
int compare_int(const void* e1, const void* e2) {//为什么要写成void *呢?
	return *(int*)e1 - *(int*)e2;
}


int main() {
	int arr[10] = { 1,2,4,3,5,6,7,8,9,10 };
	qsort(arr, 10, sizeof(arr[0]), compare_int);
	for (int i = 0; i < sizeof(arr)/sizeof(arr[0]); i++)
	{
		printf("%d ", arr[i]);
	}
	
	return 0;
}

为什么函数形参那要写成void 呢?
因为qsort不知道你要比较什么类型的数据,你传给qsort的第四个实参只是另一个被调函数的地址。void类型的指针优点在于,可以接收任何类型的地址,缺点是你不能对它进行解引用,因为它自己都不知道自己是什么类型的,不知道解引用成什么数据。void指针可以指向任何类型的数据但是它本身的数据类型是void,如果你想使用这个指针就必须先将它强制转换成它指向的那个数据类型指针
对于你自己设计的那个函数,例如上面的int compare_int(const void
e1, const void* e2)中的两个函数参数e1,e2,是不需要你来对它进行传参的,qsort内部会自动给它传参。
刚才上面讲到void型指针不能够解引用,那么当它作为参数传给你设计的那个函数时怎么进行比较呢?我们可以进行强制类型转换然后在解引用,因为我们此时已经知道比较的是什么类型的数据了。
再来对qsort函数进行一个总结:如果你要比较int类型的数据那么你就设计一个函数,函数的类型和参数与qsort的第四个参数函数指针指向的函数类型一致为int compare(const void* e1, const void* e2),因为传来的是指向int类型的空指针类型,如果你想使用指针就需要对它进行强转为它指向的数据类型然后解引用后比较,返回值为正数,0,负数,qsort会根据返回值来判断它们的大小。先设计函数为int compare(const void* e1, const void* e2)根据传来的空指针指向的什么类型强转就将它强转为它指向的类型指针然后解引用。

#include<stdio.h>
#include<stdlib.h>

//实现一个比较整型数据的函数
//int compare_int(const void* e1, const void* e2) {
//	return *(int*)e1 - *(int*)e2;
//}
//
//void test1() {
//	int arr[10] = { 1,2,4,3,5,6,7,8,9,10 };
//	qsort(arr, 10, sizeof(arr[0]), compare_int);
//	for (int i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
//	{
//		printf("%d ", arr[i]);
//	}
//}

struct Student
{
	char name[20];
	int age;
};

//int com_stu_age(const void* e1, const void* e2){
//	return *(int*)e1 - *(int*)e2;//这是错误的,传过来的e1,e2,是指向结构体的指针,所以要先强制转换成结构体指针在进行解引用
//	}
//实现一个比较结构体类型中年龄数据的函数
int com_stu_age(const void* e1, const void* e2) {
	return ((struct Student*)e1)->age - ((struct Student*)e2)->age;//e1,e2指向的类型为结构体指针struct Student*
}


void test2() {
	struct Student s[3] = { {"zhangsan",20},{"lisi",19},{"wanger",32} };
	qsort(s, sizeof(s) / sizeof(s[0]), sizeof(s[0]),com_stu_age);
	for (int i = 0; i < 3; i++)
	{
		printf("%d ", s[i].age);
	}
}


int main() {
	//test1();
	test2();
	return 0;
}
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

struct Student
{
	char name[20];
	int age;
};


//比较结构体类型中名字的函数
int com_stu_name(const void* e1, const void* e2) {
	//在对char类型数据进行比较时,要使用strcmp函数,同时包含头文件#include<string.h>
	return strcmp(((struct Student*)e1)->name, ((struct Student*)e2)->name);//e1,e2指向的类型为结构体指针struct Student*
}


void test2() {
	struct Student s[3] = { {"zhangsan",20},{"lisi",19},{"wanger",32} };
	qsort(s, sizeof(s) / sizeof(s[0]), sizeof(s[0]), com_stu_name);
	for (int i = 0; i < 3; i++)
	{
		printf("%s ", s[i].name);
	}
}


int main() {
	//test1();
	test2();
	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1122595.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【ML】cheatsheet

LR 原理与面试题目DT, Adaboost, GBDT, xgboost 原理 细节 与 例子 https://www.cnblogs.com/createMoMo/p/12635709.html xgboost挺详细的算法原理与例子 https://zhuanlan.zhihu.com/p/660468945 着重lightgbm就xgboost的改善方向 https://zhuanlan.zhihu.com/p/366952043机器…

什么是卷积神经网络?解决了什么问题?

什么是卷积神经网络&#xff1f; 卷积神经网络&#xff08;Convolutional Neural Network&#xff0c;CNN&#xff09;是一种深度神经网络模型&#xff0c;主要用于图像识别、语音识别和自然语言处理等任务。它通过卷积层、池化层和全连接层来实现特征提取和分类。 解决了什么问…

pycharm使用Git拉取最新代码(配置了远程服务器)

首先分享一下如何在pycharm设置代理&#xff08;毕竟pull代码往往是从GitHub上&#xff09;。因为即便本地开启了代理&#xff0c;PyCharm并不会自动使用它。需要在PyCharm的设置中手动配置代理。 下面是在PyCharm中设置代理的步骤&#xff1a; 主菜单中选择File > Settin…

Node学习笔记之MySQL基本使用

使用 SQL 管理数据库 其实写接口简单来说就是操作数据库数据&#xff0c;所以我们需要学会数据库的增、删、查、改等基本操作 1. 什么是 SQL SQL&#xff08;英文全称&#xff1a;Structured Query Language&#xff09;是结构化查询语言&#xff0c;专门用来访问和处理数据…

Kubernetes技术与架构-网络 1

基于OSI网络模型&#xff0c;Kubernetes集群的网络策略包括7层负载均衡的网关路由策略&#xff0c;以及4层3层的网络IP地址策略&#xff0c;这些网络策略是保证Kubernetes集群内Pod之间的网络访问的互联互通&#xff0c;本文主要描述Kubernetes集群的网络策略的基本使用方式。 …

基于nodejs+vue旅行社网站系统

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;…

Linux笔记之diff和vimdiff

Linux笔记之diff和vimdiff code review! 文章目录 Linux笔记之diff和vimdiff一.diff1.1.使用diff比较文件夹1.2.使用diff比较文件1.4.colordiff——带颜色输出差异 二.vimdiff2.1.vimdiff颜色差异2.2.vimfiff调整栏宽2.3.修改颜色变谈&#xff0c;使代码可以看清楚2.4.vimdif…

[AUTOSAR][诊断管理][ECU][$14] 清除诊断相关信息

文章目录 一、简介(1)应用场景(2)清除DTC原理(3) 请求格式二、示例代码(1) 14_cls_dtc_info.c三、 常见bug大揭秘一、简介 根据ISO14119-1标准中所述,诊断服务14主要用于Client向Server(ECU)请求清除诊断相关信息。 (1)应用场景 一般而言,14诊断服务,主要应用场景…

面向对象(基础)特征一:封装性(encapsulation)

文章目录 一、介绍&#xff08;1&#xff09;封装性&#xff08;2&#xff09;权限修饰符 二、案例&#xff08;1&#xff09;案例1 三、练习&#xff08;1&#xff09;练习1&#xff08;2&#xff09;练习2&#xff08;3&#xff09;练习3&#xff08;4&#xff09;练习4 面向…

【2023年11月第四版教材】软考高项极限冲刺篇笔记(3)

8 成本管理 成本类型:可变成本、固定成本、直接成本、间接成本、机会成本、沉没成本 应急储备:成本基准内 管理成本:成本基准外 进度偏差:SV,SPI 成本管理主要是规划和控制 成本估算 类比估算 参数估算 自上而下估算 三点估算 备选方案分析 储备分析 质量成本 总资…

strstr函数和strtok函数

文章目录 strstr函数函数使用函数模拟实现strtok函数 strstr函数 参数为两个字符串的地址&#xff0c;在str1中找str2不包括结束符。 函数使用 #include<stdio.h> #include<string.h>int main() {char* str1 "abcdeffgmnlo";char* str2 "de"…

《语音优先》智能语音技术驱动的交互界面设计与语音机器人设计(译者序)...

“言为心声,语为心境”&#xff0c;语言与对话是我们沟通与协作的重要方式。而智能语音技术是一种基于人工智能和自然语言处理技术的语音交互技术。它可以通过语音识别技术将用户的语音指令转换为文本&#xff0c;然后通过自然语言处理技术对文本进行分析和理解&#xff0c;最终…

TP-LINK XDR6088 WiFi6路由器 简单开箱评测

TL-XDR6088易展版AX6000双频WiFi6路由器 简单开箱测评&#xff0c;双2.5G网口&#xff0c;双频8流&#xff0c;8颗FEM&#xff0c;支持Docker。 TP-LINK XDR5470 WiFi6路由器 简单开箱评测&#xff1a;https://blog.zeruns.tech/archives/725.html TP-LINK XDR3040 WiFi6路由…

WinMIPS64汇编指令详解

目录 MIPS指令R I J三种格式 MIPS五种寻址方式 立即数寻址 寄存器寻址 基址寻址 PC相对寻址 伪直接寻址 WinMIPS64汇编指令 助记 从内存中加载数据 lb lbu lh lhu lw lwu ld l.d lui 存储数据到内存 sb sh sw sd s.d 算术运算 daddi daddui dadd…

C++笔记之vector的初始化以及assign()方法

C笔记之vector的初始化以及assign()方法 —— 2023年4月15日 上海 code review 文章目录 C笔记之vector的初始化以及assign()方法代码——实践出真知0. 空的vector1. 花括号(initializer_list)——最推荐的初始化方法2. 花括号3. 圆括号花括号4. 圆括号5. 圆括号6. 指针花括号7…

我做不到受每个人喜欢

我做不到受每个人喜欢 我想描述一下昨天发生争吵后我个人的观点&#xff0c;希望能够重新呈现出一种积极的态度。 首先&#xff0c;让我简要梳理一下事件的经过&#xff0c;当天我像往常一样去另一个宿舍找人聊天&#xff0c;可能因为说话声音有点大&#xff0c;坐在我后面的那…

GUI设计——PyQt5快速入门

一、学习目标 了解有关GUI界面设计的基本语法能够编写简单的界面设计程序 二、PyQt5 安装与环境配置 首先&#xff0c;本人通过网上的教程&#xff0c;在Index of / (qt.io)官网上下载好了 Qt Designer 和 Qt Creator 。本人下载的版本为 5.14。随后&#xff0c;通过网络的资源…

【Spring Cloud Alibaba】seata分布式事务官方入门案例(实战版)

文章目录 1. 业务介绍1.1. 用例1.2. 架构图1.3. 3个服务的代码及业务逻辑&#xff08;略&#xff09; 2. SEATA 的分布式交易解决方案3. 由Dubbo SEATA提供支持的示例&#xff08;实战&#xff09;3.1. 步骤 1&#xff1a;建立数据库&#xff0c;如seata数据库3.2. 步骤 2&…

OSPF基础实验

一、实验拓扑 二、实验要求 1、按照图示配置 IP 地址 2、R1&#xff0c;R2&#xff0c;R3 运行 OSPF 使内网互通&#xff0c;所有接口(公网接口除外)全部宣告进 Area 0; 要求使用环回口作为 Router-id 3、业务网段不允许出现协议报文 4、R5 模拟互联网&#xff0c;内网通过…

Andriod学习笔记(二)

页面设计的零碎知识 通用属性设置文本大小设置视图宽高设置视图的对齐方式 页面布局LinearLayoutRelativeLayoutGridLayoutScollView 按钮触控ButtonImageViewImageButton 通用属性 设置文本大小 纯数字的setTextSize方法&#xff0c;内部默认字体单位为sp&#xff0c;sp是An…