【c语言】对结构体数组按照某项规则进行排序

这篇具有很好参考价值的文章主要介绍了【c语言】对结构体数组按照某项规则进行排序。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

        这是基于qsort()函数进行的简单排序。(附带其他类型的数组使用qsort()进行的排序)

目录

一、qsort()函数

二、compare()函数

1.结构体数组

1)升序实现

2)降序实现

2.整型数组

为什么不直接返回 a>b(a)?<>

如果就是想用 a>b(a)返回?<>

 1)升序实现

2)降序实现

3.浮点型数组

1)升序实现

2)降序实现

三、效果图

总结



前言

        基于qsort()函数进行的排序最有用的莫过于在此对于结构体数组进行排序了。此外,若能结合函数指针,更是能够实现“想降就降,想升就升”的美好局面。


一、qsort()函数

void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )(const void *elem1, const void *elem2 ) );(来源msdn)

        base:传过去的数组

        num:数组中元素的个数

        width:数组中每个元素有多大

        compare():此函数指针是需要自己实现的、根据什么规则进行的排序函数

二、compare()函数

        须根据需要对于参数进行指针类型的转化。

        若对字符型数组进行排序,那就转换成字符型指针。(char*)

        若对整型数组进行排序,那就转换成整型指针。(int*)       

        若对浮点型数组进行排序,那就转换成浮点型指针。(float*)

        若对结构体数组的某项进行排序,那就转换成结构体指针。(struct xxx*)

1.结构体数组

        返回的是两个结构体指针解引用后相比较的结果。

1)升序实现

代码如下(示例):

int Ascend(const void* p1, const void* p2)
{
	const stu* x = p1;
	const stu* y = p2;
	// 对于结构体进行二级排序:
	// 如果年龄相等,谁成绩高谁在前面
	if (x->age == y->age)
	{
		return (x->score < y->score);
	}
	else
	{
		return (x->age < y->age);
	}
}

2)降序实现

代码如下(示例):

int Descend(const void* p1, const void* p2)
{
	const stu* x = p1;
	const stu* y = p2;
	// 对于结构体进行二级排序:
	// 如果年龄相等,谁成绩高谁在前面
	if (x->age == y->age)
	{
		return (x->score < y->score);
	}
	else
	{
		return (x->age < y->age);
	}
}

2.整型数组

        返回的是两个int指针解引用后相减的结果。(用三目运算符+大于小于号也可以)

为什么不直接返回 a>b(a<b)?

        如下图:因为qsort()在判断时是需要判断两个参数谁大谁小,是需要一个正数或者负数的,但是直接返回a>b(a<b)的话,这个表达式的值只有0和非0,非0会被认为是相等,从而不进行交换。

c语言结构体数组排序,c语言学习笔记,c语言,学习,经验分享,算法

如果就是想用 a>b(a<b)返回?

        可以使用三目运算符来规避a<b时值为0的情况。

c语言结构体数组排序,c语言学习笔记,c语言,学习,经验分享,算法

c语言结构体数组排序,c语言学习笔记,c语言,学习,经验分享,算法

 1)升序实现

代码如下(示例):

void ArrComp(const void* p1, const void* p2)
{
	const int* x = p1;
	const int* y = p2;
	return *x - *y;
}

2)降序实现

代码如下(示例):

void ArrDescend(const void* p1, const void* p2)
{
	const int* x = p1;
	const int* y = p2;
	return *y - *x;
}

3.浮点型数组

        返回的是两个float指针解引用相比较的结果,使用三目运算符进行判断(目的是为了判断大小后有个正负)。

1)升序实现

代码如下(示例):

void FloatArrAscend(const void* p1, const void* p2)
{
	const float* x = p1;
	const float* y = p2;
	return *x > *y ? 1 : -1;
}

2)降序实现

代码如下(示例):

void FloatArrDescend(const void* p1, const void* p2)
{
	const float* x = p1;
	const float* y = p2;
	return *y < *x ? 1 : -1;
}

三、效果图

c语言结构体数组排序,c语言学习笔记,c语言,学习,经验分享,算法

总结

        qsort()函数源码在c库中使用的是快排进行的排序函数,结合函数指针,可以实现快速地升、降序的排序。文章来源地址https://www.toymoban.com/news/detail-776397.html

到了这里,关于【c语言】对结构体数组按照某项规则进行排序的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • Java中List对象集合按照对象中某字段进行排序

    在Java中,可以使用List集合对象的sort(Comparator? super E c)方法,按照对象中某字段对List集合进行排序 栗子: 打印输出结果如下:

    2024年02月12日
    浏览(12)
  • 《综合与Design_Compiler》学习笔记——第一章综合综述 第二章verilog语言结构到门级的映射 第三章 使用DC进行综合

    《综合与Design_Compiler》学习笔记——第一章综合综述 第二章verilog语言结构到门级的映射 第三章 使用DC进行综合

    2023.6.25 2023.6.27 和之前学的芯动力mooc中很多内容相似,这篇整理的逻辑更好些 将RTL代码转换到基于工艺库的门级网表。一般分为如下三个步骤。 (1)逻辑级综合 设计被描述成 布尔等式 的形式,触发器、锁存器这样的基本单元采用元件例化(instantiate)的方式表达出来,下面是

    2024年02月12日
    浏览(16)
  • C语言学习笔记:数组

    C语言学习笔记:数组

    ✨博文作者:烟雨孤舟 💖 喜欢的可以 点赞 收藏 关注哦~~ ✍️ 作者简介: 一个热爱大数据的学习者 ✍️ 笔记简介:作为大数据爱好者,以下是个人总结的学习笔记,如有错误,请多多指教! 目录 ​​​​​​​ 简介 数组声明 数组初始化 访问数组元素 多维数组 二维数组

    2024年02月09日
    浏览(9)
  • C语言学习分享(第六次)------数组

    C语言学习分享(第六次)------数组

    💓博主CSDN主页:杭电码农-NEO💓   ⏩专栏分类:C语言学习分享⏪   🚚代码仓库:NEO的学习日记🚚   🌹关注我🫵带你学习更多C语言知识   🔝🔝 啊~~,很久没有更新C语言知识了,各位久等了,本篇文章在了解了数组的基本知识后, 着重于给大家实现两个小游戏:三子棋和扫雷

    2024年02月03日
    浏览(18)
  • perl脚本语言学习1——基础篇:变量、数组、哈希数组、循环、文件、函数

    2023.3.18 今天下载虚拟机把电脑磁盘内容弄到乱七八糟,难受 发现每次学习遇到一个坎,感觉面前是一座大山,越过去之后又对前途充满了希望 perl:practical extraction report language 实用提取和报表语言 从字面上看主要与文本处理相关 变量定义: my 存储 数字、字符、字符

    2024年02月12日
    浏览(10)
  • 【C语言】从零开始学习数组

    【C语言】从零开始学习数组

    💓博客主页:江池俊的博客 ⏩收录专栏:C语言初阶之路 👉其他专栏:数据结构探索 💻代码仓库:江池俊的代码仓库 🎪 社区:GeekHub社区 (欢迎大家加入与我一起探讨学习经验) 🍁 如果觉得博主的文章还不错的话,请点赞👍收藏🌟 三连支持一下博主💞 目录 一、一维数

    2024年02月15日
    浏览(9)
  • C语言学习day15:数组强化训练

    C语言学习day15:数组强化训练

    题目一: 称体重:分别给10个值,来获得最大值 思路: 定义数组,给数组内赋10个值 第一个下标的值与第二个下标的值进行比较 定义max,将比较得来的较大的值赋值给max 一直比较直到比较到最后一个下标,将得到的最大值赋值给max 代码: 结果: 题目二:数组逆置 数组逆

    2024年02月21日
    浏览(8)
  • 前端学习C语言 - 数组和字节序

    本篇主要介绍: 一维二维数组 、 字符数组 、 数组名和初始化注意点 以及 字节序 。 初始化 有以下几种方式对数组初始化: Tip :以上写法创建的数组都是 不可变大小的 。 练习1 题目 : int a[5] = {1} ,请问 a 的每个值是多少? 输出: 1 0 0 0 0 。 在C和C++中,当我们创建数组

    2024年02月09日
    浏览(10)
  • C语言学习记录——找数组中的鞍点

    C语言学习记录——找数组中的鞍点

    目录 C语言中 鞍点的定义  代码的实现 思路分析图解  指一个矩阵中,即该位置上的元素在该行上最大,在该列上最小。 一个二维数组可能没有鞍点。 例如:1,2,3            4,5,6            7,8,9 该矩阵中,鞍点为3所在的位置。 即数组坐标[ 0 ] [ 2 ],在第一行第三

    2024年02月04日
    浏览(31)
  • C语言学习笔记——C语言结构

    C语言是一种面向过程的结构化的语言,同时具有高级语言和汇编语言的优点 所有的C语言程序经过编译和连接之后才能被计算机执行 头文件是一种特殊的文件,记录了很多可以直接引用头文件然后使用的函数,也可通过#define声明函数、变量、宏等的定义 头文件通常包含在源

    2024年02月11日
    浏览(10)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包