模拟实现qsort函数
qsort函数的定义及其使用
这个在上一篇文章已经讲过了,感兴趣的可以看看上一篇
添加链接描述
模拟函数
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int cmp_int(const void* p1, const void* p2)
{
return (*(int*)p1 - *(int*)p2);
}
void swap(char* buff1, char* buff2, int size)
{
int i = 0;
char tmp = 0;
for (i = 0; i < size; i++)
{
tmp = *buff1;
*buff1 = *buff2;
*buff2 = tmp;
*buff1++;
*buff2++;
}
}
void bubble_sort(void* base, int num, int size, int (*cmp)(const void*, const void*))
{
int i = 0;
for (i = 0; i < num - 1; i++)
{
for (int j = 0; j < num - 1 - i; j++)
{
if (cmp((char*)base + j * size, (char*)base + (j + 1) * size) > 0)
{
swap((char*)base + j * size, (char*)base + (j + 1) * size, size);
}
}
}
}
模拟qsort解析
在模拟qsort函数的时候我们使用的是冒泡函数模拟qsort函数,所以我们的思路就是冒泡函数和我们要模拟函数的区别是什么,qsort函数的排序对象是任意类型的,而冒泡函数的排序对象是只有整型;所以我们提出了以下的问题。
- 如何把排序对象从整形转化为任意类型。我们用void的指针,再转化为char类型(至于为什么转化为char*类型我们下面再说明)
- 不同类型的数据不能用简单使用大于和小于号。将两个元素比较转化为以函数参数的形式传递
- 不同数据交换也有差异
if (cmp((char*)base + j * size, (char*)base + (j + 1) * size) > 0)
{
swap((char*)base + j * size, (char*)base + (j + 1) * size, size);
}
这里首先声明,swap函数是我们自己定义的,目的是实现两个元素交换。
swap函数
void swap(char* buff1, char* buff2, int size)
{
int i = 0;
char tmp = 0;
for (i = 0; i < size; i++)
{
tmp = *buff1;
*buff1 = *buff2;
*buff2 = tmp;
*buff1++;
*buff2++;
}
- 这个函数有三个参数,第一个是数组中某个元素,第二个是下一个元素,第三个就是该类型所占字节的大小。
- 这里我们要重点说一说char*类型的作用,我们上面的分析中的第一条,因为要比较所有类型,char类型只占一个字节,对于所有类型的数据都可以适用,比如我们要比较的是int类型的数据,(char)base + j * size,size就是4,假如j=1,那么就是跳过了4个字节,其他类型的元素也可以适用*
- 在swap函数中就是一个字节一个字节的交换,直到全部完成。
函数实战
整型
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int cmp_int(const void* p1, const void* p2)
{
return (*(int*)p1 - *(int*)p2);
}
void swap(char* buff1, char* buff2, int size)
{
int i = 0;
char tmp = 0;
for (i = 0; i < size; i++)
{
tmp = *buff1;
*buff1 = *buff2;
*buff2 = tmp;
*buff1++;
*buff2++;
}
}
void bubble_sort(void* base, int num, int size, int (*cmp)(const void*, const void*))
{
int i = 0;
for (i = 0; i < num - 1; i++)
{
for (int j = 0; j < num - 1 - i; j++)
{
if (cmp((char*)base + j * size, (char*)base + (j + 1) * size) > 0)
{
swap((char*)base + j * size, (char*)base + (j + 1) * size, size);
}
}
}
}
void text1()
{
int arr[] = { 9,8,7,6,5,4,3,2,1,0 };
int sz = sizeof(arr) / sizeof(arr[0]);
bubble_sort(arr, sz, sizeof(arr[0]), cmp_int);
for (int i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
}
int main()
{
text1();
return 0;
}