#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int cmp(void* p1, void* p2)
{
return *(int*)p1 - *(int*)p2;//转换成int类型指针读取4字节的数据解引用得元素用来比大小
}
void swap(char* p1, char* p2, int width)//精确到以1个字节相互交换
{
int i = 0;
for (i = 0; i < width; i++)
{
char* temp = *(p1 + i);
*(p1 + i) = *(p2 + i);
*(p2 + i) = temp;
}
}
void my_qsort(void* arr, int len, int width)//void*可以接受任意类型的数据,方法用冒泡排序法
{
int i = 0; int j = 0;
for (i = 0; i < len; i++)
{
for (j = 0; j < len - 1 - i; j++)
{
if (cmp((char*)arr + j * width, (char*)arr + (j + 1) * width) > 0)//开始比较,因为接受的是void*类型,所以用char*类型转换在×宽度得到每个元素原始数据
{
swap((char*)arr + j * width, (char*)arr + (j + 1) * width, width);//交换数据,精确到以1个字节为单位的排序
}
}
}
}
int main()
{
int arr[] = { 7,6,5,4,3,2,1};
int sz = sizeof(arr) / sizeof(arr[0]);
printf("%d\n", sz);
my_qsort(arr,sz,sizeof(arr[0]),cmp);//排序的数组首地址,数组元素个数,元素的大小(字节),回调函数
for (int i = 0; i < sz; printf("%d ", arr[i++]));
return 0;
}
标签:p2,arr,函数,int,void,qsort,char,width From: https://www.cnblogs.com/godex/p/16631568.html