热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C语言中qsort函数的使用详解

本文详细介绍了C语言中的qsort函数,包括其四个参数的具体含义及如何自定义比较函数,同时提供了多种类型的数组和结构体排序示例。

qsort函数是C标准库中用于排序的一个强大工具,它能够对任意类型的数据进行排序。该函数接受四个参数:



  • 第一个参数是指向待排序数组的指针。

  • 第二个参数是数组中元素的数量。

  • 第三个参数是每个元素的大小,通常通过sizeof操作符获取。

  • 第四个参数是一个指向比较函数的指针,这个函数决定了排序的规则。


前三个参数相对直观,而最后一个参数——比较函数,则是实现特定排序逻辑的关键所在。


基本示例:整数数组的qsort排序


从大到小排序



#include 

int cmp_desc(const void *a, const void *b) {
return (*(int*)b - *(int*)a);
}

// 使用qsort函数进行排序
qsort(arr, n, sizeof(int), cmp_desc);


从小到大排序



#include 

int cmp_asc(const void *a, const void *b) {
return (*(int*)a - *(int*)b);
}

// 使用qsort函数进行排序
qsort(arr, n, sizeof(int), cmp_asc);


七种qsort排序方法


1. 对int类型数组排序



int arr[100];

int cmp_int(const void *a, const void *b) {
return (*(int*)a - *(int*)b);
}

qsort(arr, n, sizeof(int), cmp_int);


2. 对char类型数组排序(与int类型类似)



char arr[100];

int cmp_char(const void *a, const void *b) {
return (*(char*)a - *(char*)b);
}

qsort(arr, n, sizeof(char), cmp_char);


3. 对double类型数组排序



double arr[100];

int cmp_double(const void *a, const void *b) {
return (*(double*)a > *(double*)b) ? 1 : -1;
}

qsort(arr, n, sizeof(double), cmp_double);


4. 对结构体进行一级排序



struct Item {
double value;
int other;
} items[100];

int cmp_item(const void *a, const void *b) {
return ((*(struct Item*)a).value > (*(struct Item*)b).value) ? 1 : -1;
}

qsort(items, n, sizeof(struct Item), cmp_item);


5. 对结构体进行二级排序



struct Item {
int x;
int y;
} items[100];

int cmp_item2(const void *a, const void *b) {
struct Item *ia = (struct Item*)a;
struct Item *ib = (struct Item*)b;
if (ia->x != ib->x)
return ia->x - ib->x;
else
return ib->y - ia->y;
}

qsort(items, n, sizeof(struct Item), cmp_item2);


6. 对结构体进行三级排序(均按升序)



typedef struct {
int num;
int length;
int width;
} Item;

int cmp_item3(const void *a, const void *b) {
Item *ia = (Item*)a;
Item *ib = (Item*)b;
if (ia->num != ib->num)
return ia->num - ib->num;
else if (ia->length != ib->length)
return ia->length - ib->length;
else
return ia->width - ib->width;
}

qsort(items, n, sizeof(Item), cmp_item3);


7. 对字符串进行排序



struct Item {
int data;
char str[100];
} items[100];

int cmp_str(const void *a, const void *b) {
return strcmp(((struct Item*)a)->str, ((struct Item*)b)->str);
}

qsort(items, n, sizeof(struct Item), cmp_str);


8. 计算几何中求凸包的cmp函数



struct Point {
int x;
int y;
};

int cmp_convex_hull(const void *a, const void *b) {
struct Point *pa = (struct Point*)a;
struct Point *pb = (struct Point*)b;
if (calc(*pa, *pb, p[1]) <0)
return 1;
else if (!calc(*pa, *pb, p[1]) && dis(pa->x, pa->y, p[1].x, p[1].y) x, pb->y, p[1].x, p[1].y))
return 1;
else
return -1;
}

qsort(points, n, sizeof(struct Point), cmp_convex_hull);


推荐阅读
  • 本文介绍如何在Linux服务器之间使用SCP命令进行文件传输。SCP(Secure Copy Protocol)是一种基于SSH的安全文件传输协议,支持从远程机器复制文件到本地服务器或反之。示例包括从192.168.45.147复制tomcat目录到本地/home路径。 ... [详细]
  • 本文探讨了如何通过最小生成树(MST)来计算严格次小生成树。在处理过程中,需特别注意所有边权重相等的情况,以避免错误。我们首先构建最小生成树,然后枚举每条非树边,检查其是否能形成更优的次小生成树。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 如何在WPS Office for Mac中调整Word文档的文字排列方向
    本文将详细介绍如何使用最新版WPS Office for Mac调整Word文档中的文字排列方向。通过这些步骤,用户可以轻松更改文本的水平或垂直排列方式,以满足不同的排版需求。 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • 本文介绍如何在应用程序中使用文本输入框创建密码输入框,并通过设置掩码来隐藏用户输入的内容。我们将详细解释代码实现,并提供专业的补充说明。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 高效解决应用崩溃问题!友盟新版错误分析工具全面升级
    友盟推出的最新版错误分析工具,专为移动开发者设计,提供强大的Crash收集与分析功能。该工具能够实时监控App运行状态,快速发现并修复错误,显著提升应用的稳定性和用户体验。 ... [详细]
  • andr ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
author-avatar
懒懒加菲猫爱小狐狸
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有