原来还有【快速排序】 qsort() 函数

2024 - 10 - 01 - 笔记 - 20
作者(Author): 郑龙浩 / 仟濹(网名)

qsort()函数

① 介绍:

包含头:#include <stdlib.h>

C语言本身提供的一个函数。

qsort函数是使用【快速排序】思想实现的一个排序函数

qsort函数可以排序任意类型的数据

提示:可以使用MSDN软件搜索此函数

注:类型是const void 的指针elem

  • elem不可以改变指向的变量的值
  • void 的指针elme可以指向任意类型的变量
  • viod 的指针elme是不能直接进行解引用的操作的
  • elme 不可以进行解引用操作,也不能进行+-整数操作
c 复制代码
void qsort( void *base, //指针 - 要排序的数据的起始位置
           size_t num, //整型 - 待排序的数据元素的个数
           size_t width, //整型 - 待排序的数据元素的大小(占了几个字节)
           int (__cdecl *compare )(const void *elem1, const void *elem2 ) );//函数指针 - 比较函数 - 存放比较函数的地址,说白了就是根据我提供的函数进行比较。
//elem1 与 elem2 是要比较的两个元素的地址
//之前一直疑惑为什么只有两个元素进行比较
//其实还需要自己写一个函数,里面有两个参数,然后自己定义如何比较这两个数据
c 复制代码
_cdecl - 函数调用约定 - 约定了函数按照C的形式去调用//可以删掉_cdecl
//单词:
base - 库
num - 数字
width - 宽度
compare - 比较
elem - 元素、基本的

② qsort函数 排序【整型数据】:

平时所联系的多数也是整数比较

注意:在定义判断函数的时候,返回值必须得有大于0、小于0、等于0三种情况(包括1, 0, -1)

c 复制代码
//先将表示比较规则的函数写出来
int compare_int(const void* elem1, const void* elem2)//有规定,返回值必须是>0,==0,<0这三个
{
    //这尽量就不要些if比较谁大谁小了,看起来非常的不方便
    
    return (*(int*)elem1 - *(int*)elem2);//返回>0 ==0 <0
    //判断函数必须返回返回>0 ==0 <0 这三种情况,或者1,0,-1也可以
    //切记:千万不可*elem1,因为void的指针不可直接解引用,必须将指针强制类型转换以后才可进行解引用
}
int main()
{
    int arr[10] = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
    qsort( arr, 10, sizeof( arr[0] ), compare_int  );
}

③ qsort排序 【结构体数据】

结构体的比较

c 复制代码
int compare_Stu_Name(const void* elem1, const void* elem2);
int compare_Stu_Age(const void* elem1, const void* elem2);
    
int struct Student
{
    char[20] = "aaa";
    int age;
}
int main()
{
    struct Stu student[] = { { "aaa", 10 }, { "bbb", 11 }, { "ccc", 12 }, { "ddddd", 13 }, { "eeeeee", 14 } };
    //按姓名排序
	qsort( student, 5, sizeof( student[0] ), compare_Stu_Name );
    //按年龄排序
	qsort( student, 5, sizeof( student[0] ), compare_Stu_Age );
    
}



//写比较结构体中姓名成员的规则
int compare_Stu_Name(const void* elem1, const void* elem2)
{
    //强制类型转换:将无类型的指针强制转换为 struct Stu 类型
    strcmp( ((struct Stu*)elem1) -> name, ((struct Stu*)elem2) -> name )//只返回三种情况
}
//写比较结构体中年龄成员的规则
int compare_Stu_Age(const void* elem1, const void* elem2)
{
	return (struct Stu*)elem1 - (struct Stu*)elem2);//只返回三种情况
}
相关推荐
ღ᭄ꦿ࿐Never say never꧂几秒前
Redis 五大基本数据类型及其应用场景进阶(缓存预热、雪崩 、穿透 、击穿)
java·数据库·redis·缓存预热、雪崩、击穿、穿透·五大基本数据类型
It'sMyGo3 分钟前
javascript手写实现instanceof函数 介绍判断数组的方法
开发语言·javascript·原型模式
luthane10 分钟前
python 实现gradient boosting regressor梯度增强回归器算法
python·算法·boosting
Czi.18 分钟前
Build a Large Language Model (From Scratch)学习汇总
人工智能·学习·语言模型
程序员阿鹏27 分钟前
HashMap为什么线程不安全?如何实现线程安全
java·开发语言·数据结构·安全·eclipse·intellij-idea
sp_fyf_202428 分钟前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-09-30
人工智能·算法·计算机视觉·语言模型·自然语言处理
可靠百灵鸟31 分钟前
Python操作TXT文本:从入门到精通
数据库·python·mysql
Death20035 分钟前
序列化与反序列化
c语言·c++·qt·c#
猫毛已经快要掉光的小猫38 分钟前
【算法】leetcode热题100 146.LRU缓存.&& container/list用法
算法·leetcode·缓存·go
m0_675447081 小时前
Java ERP管理系统源码解析:微服务架构实践Spring Cloud Alibaba与Spring Boot
java·erp管理系统源码