(C语言)qsort函数模拟实现

qort函数是一个排序函数,能够排任意类型的数组。

这篇文章教大家用c语言冒泡排序的方法来模拟实现qsort函数

写一个函数进行,首先肯定是要将被排序数组的地址给传递过去,以及数组元素的个数(用来确定待排数组的冒泡排序的次数),其他是否还有参数要进行传递还未知,先不用管。

paixu(b,num,sz,bijiao);

接着我们来书写这个函数

首先先来书写数组两个元素排序的代码,排序用简单的冒泡排序进行处理即可;问题首先是如何比较两个元素之间的大小,和将两个元素进行排序我们很容易想到,可以通过地址来找到被查找元素的地址,接着通过每个数据的大小进行数组元素的引用并进行比较,因此参数还需传递数组元素的大小

只要将各个元素的地址作为参数进行传递给比较函数即可,地址我们将其转化成char*类型的指针以此来方便地址的确认和查找,而比较函数可以由使用者自己来进行书写。并且作为回调函数来进行比较使用,并返回参数值来确定比较结果。

确定比较结果之后,就可以通过指针来将元素进行调换,因此可以写一个调换函数,

我们跟之前一样通过元素大小和指针来找到被调换元素,因此参数还需要将元素大小传递过去。

我们因为不知道被调换元素类型,只能将一个一个字节进行调换,可以用for循环来调换,传递的元素大小参数也在此刻派上用场!

qsort函数已经模拟实现,下回见!!!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值