其他分享
首页 > 其他分享> > qsort函数

qsort函数

作者:互联网

#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
来源: https://www.cnblogs.com/godex/p/16631568.html