qort函数是一个排序函数,能够排任意类型的数组。
这篇文章教大家用c语言冒泡排序的方法来模拟实现qsort函数
写一个函数进行,首先肯定是要将被排序数组的地址给传递过去,以及数组元素的个数(用来确定待排数组的冒泡排序的次数),其他是否还有参数要进行传递还未知,先不用管。
paixu(b,num,sz,bijiao);
接着我们来书写这个函数
首先先来书写数组两个元素排序的代码,排序用简单的冒泡排序进行处理即可;问题首先是如何比较两个元素之间的大小,和将两个元素进行排序我们很容易想到,可以通过地址来找到被查找元素的地址,接着通过每个数据的大小进行数组元素的引用并进行比较,因此参数还需传递数组元素的大小
只要将各个元素的地址作为参数进行传递给比较函数即可,地址我们将其转化成char*类型的指针以此来方便地址的确认和查找,而比较函数可以由使用者自己来进行书写。并且作为回调函数来进行比较使用,并返回参数值来确定比较结果。
确定比较结果之后,就可以通过指针来将元素进行调换,因此可以写一个调换函数,
我们跟之前一样通过元素大小和指针来找到被调换元素,因此参数还需要将元素大小传递过去。
我们因为不知道被调换元素类型,只能将一个一个字节进行调换,可以用for循环来调换,传递的元素大小参数也在此刻派上用场!
qsort函数已经模拟实现,下回见!!!