模拟实现qsort函数

模拟实现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函数的排序对象是任意类型的,而冒泡函数的排序对象是只有整型;所以我们提出了以下的问题。

  1. 如何把排序对象从整形转化为任意类型。我们用void的指针,再转化为char类型(至于为什么转化为char*类型我们下面再说明)
  2. 不同类型的数据不能用简单使用大于和小于号。将两个元素比较转化为以函数参数的形式传递
  3. 不同数据交换也有差异
			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;
}

在这里插入图片描述

  • 15
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 14
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

tpoog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值