C语言(自己的qsort) //初学者练习记录

 

int main()//主函数代码
{
	int arr[] = { 3,1,2,3,4,6,44,33,77,66,90,9 };
	int sz = sizeof(arr) / sizeof(arr[0]);//元素个数

    //过程

	//qsort(arr, sz, sizeof(arr[0]), arr_compare);
	my_qsort(arr, sz, sizeof(arr[0]), arr_compare);

    //显示排序结果
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}

	return 0;
}

 

//分析  qsort
//qsort 采用的是快速排序
//要传入四个参数    
//1.首元素地址  2.元素字节大小  3.单个元素字节大小  4.比较方法
//qsort 需要引用头文件<stdlib.h>

//比较方法
//返回值  1>   =0   1<
int arr_compare(const void* e1, const void* e2)
{
	return (*((int*)e1))-(*((int*)e2));
}



void my_sort(char* arr1,char* arr2,int width)
{
	for (int k = 0; k < width; k++)
	{
		char tmp = *arr1;        //这里的交换要交换元素
		*arr1 = *arr2;           //因为传进来的是地址,解引用一下后就成了元素
		*arr2 = tmp;             //char类型占一个字节
		arr1++;                  //在这刚好传经来的是第一个元素开始,和第二个元素开始
		arr2++;                  //将俩个的最小位开始交换就可以将这个元素彻底交换
	}                            //包容性很强

}


void my_qsort(void* arr, int sz, int width, int(*bijiao)(void*, void*))
{
	int i = 0;
	for (i = 0; i < sz - 1; i++)
	{
		for (int j = 0; j < sz-1-i; j++)
		{

			if(    arr_compare( (char*)arr+j*width   ,   (char*)arr+(j+1)*width)  >0  )
			{
				//排序
                //传进去的是第一个元素开始和第二个元素开始,和元素长度
				my_sort(   (char*)arr + j * width , (char*)arr + (j + 1) * width, width);

			}
		}
	}
}

初学者学习记录

有不足之处还望大佬指导

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值