当前位置: 首页 > news >正文

【c语言基础学习】qsort快速排序函数介绍与使用

在C语言中,qsort 函数用于对数组进行快速排序。以下是详细的使用方法及示例:


一、函数原型

#include <stdlib.h>void qsort(void *base, size_t nmemb, size_t size, int (*compar)(const void *, const void *)
);

二、参数说明

参数说明
base指向数组首元素的指针(即数组名)
nmemb数组的元素个数
size每个元素的大小(字节数,可用 sizeof 获取)
compar比较函数的指针,用于定义排序规则(返回负数、0、正数表示第一个参数应排在前面、相等、后面)

三、比较函数模板

比较函数的参数是 const void*,需在内部转换为实际类型后再比较:

int compare(const void *a, const void *b) {// 将 void* 转为实际类型(如 int*)const Type *ptrA = (const Type*)a;const Type *ptrB = (const Type*)b;// 定义比较规则:// 若 a < b,返回负数;a > b,返回正数;相等返回0return (*ptrA - *ptrB); // 示例:升序排列
}

四、使用示例

1. 对整数数组升序排序
#include <stdio.h>
#include <stdlib.h>int compare_ints(const void *a, const void *b) {int arg1 = *(const int*)a;int arg2 = *(const int*)b;return (arg1 > arg2) - (arg1 < arg2); // 避免整数溢出
}int main() {int arr[] = {5, 2, 8, 1, 3};size_t len = sizeof(arr) / sizeof(arr[0]);qsort(arr, len, sizeof(int), compare_ints);for (size_t i = 0; i < len; i++) {printf("%d ", arr[i]); // 输出:1 2 3 5 8}return 0;
}
2. 对字符串数组排序(按字典序)
#include <string.h>int compare_strings(const void *a, const void *b) {const char **str1 = (const char **)a; // 注意双指针转换const char **str2 = (const char **)b;return strcmp(*str1, *str2);
}int main() {char *strs[] = {"apple", "banana", "cherry"};size_t len = sizeof(strs) / sizeof(strs[0]);qsort(strs, len, sizeof(char*), compare_strings);for (size_t i = 0; i < len; i++) {printf("%s ", strs[i]); // 输出:apple banana cherry}return 0;
}
3. 对结构体按字段排序
typedef struct {char name[50];int age;
} Person;int compare_person_age(const void *a, const void *b) {const Person *p1 = (const Person*)a;const Person *p2 = (const Person*)b;return p1->age - p2->age; // 按年龄升序
}int main() {Person people[] = {{"Alice", 30}, {"Bob", 25}};size_t len = sizeof(people) / sizeof(people[0]);qsort(people, len, sizeof(Person), compare_person_age);for (size_t i = 0; i < len; i++) {printf("%s: %d\n", people[i].name, people[i].age); // 输出:Bob: 25 → Alice: 30}return 0;
}

五、常见问题

1. 如何实现降序排序?

在比较函数中反转返回值:

int compare_ints_desc(const void *a, const void *b) {int arg1 = *(const int*)a;int arg2 = *(const int*)b;return (arg1 < arg2) - (arg1 > arg2); // 降序排列
}
2. 如何避免整数溢出?

使用显式比较代替减法:

int compare_ints_safe(const void *a, const void *b) {int arg1 = *(const int*)a;int arg2 = *(const int*)b;if (arg1 < arg2) return -1;if (arg1 > arg2) return 1;return 0;
}
3. 为什么排序结果不正确?
  • 错误原因:比较函数未正确处理边界(如未考虑负数)。
  • 解决方案:确保比较函数对任意输入都能正确返回负/0/正值。

通过灵活定义比较函数,qsort 可排序任意类型的数据,是C语言中最通用的排序工具。

相关文章:

  • 3D开发工具HOOPS助力Hexagon智能制造突破技术瓶颈,重塑测量软件用户体验!
  • 算法——置换与排列【基础】
  • LVGL Video控件和Radiobtn控件详解
  • 【无标题】Spark-SQL编程(2)
  • 玩转Docker | 使用Docker部署Xnote笔记工具
  • 从Gradio App创建Discord Bot/Slack Bot/Website Widget(2)——从Gradio App创建Slack Bot
  • 智谱开源 9B/32B 系列模型,性价比超 DeepSeek-R1,Z.ai 平台上线
  • 疾控01-实验室信息管理系统需求分析
  • 2025.4.15六年之约day11
  • linux0.11内核源码修仙传第十三章——进程调度之fork函数
  • 用DeepSeek AI高效制作专业PPT
  • DES对称加密算法实操(python)
  • 入门-C编程基础部分:4、数据类型
  • 【力扣】day1
  • 第十一章 网络编程
  • 【设计模式】适配器模式:让不兼容的接口和谐共处
  • java开发中的设计模式之工厂模式
  • 设计模式:命令模式-解耦请求与执行的完美方案
  • DB-GPT 最新0.7.0版本Windows 部署
  • Differentiable Micro-Mesh Construction 论文阅读
  • 两部门发布“五一”假期全国森林草原火险形势预测
  • 王星昊再胜连笑,夺得中国围棋天元赛冠军
  • 龚正会见委内瑞拉副总统罗德里格斯
  • 主播说联播丨六部门出台新政!来华买买买,实惠多多多
  • 江西省宁都县政协原二级调研员谢亦礼被查
  • 对排出黑烟车辆出具合格报告,广州南沙一检测公司被罚十万元