自己来实现qsort通用函数

文章介绍了C语言中使用qsort函数实现的快速排序算法,以及如何在整形数组和结构体数组中按照特定条件(如字符串长度)进行排序,通过示例展示了冒泡排序和自定义比较函数的用法。
摘要由CSDN通过智能技术生成

一,qsort 底层使用的快速排序

void qsort(void*base,//待排序的起始地址    

                size_t num,    //待排序数据的元素个数        

                size_t size,    //待排序数据的一个元素的大小,单位是字节

            int (*compar)(const void*,const void*)//函数指针,指向一个比较函数,这个函数是用来比较两个元素的

               )   

二,整形数组排序 

1.代码思路 

(1)main主函数

int main()
{
    test1();      //整形数组排序
    return 0;
}

(2)test()函数

void test1()
{
    int arr[] = { 9,8,7,6,5,4,3,2,1,0 };
    //降序排为升序;
    int sz = sizeof(arr) / sizeof(arr[0]);
    printf_arr(arr, sz);       //这是一个打印数组函数-排序前输出
    my_sort(arr, sz, sizeof(arr[0]), my_compar_int);
    printf_arr(arr, sz);                     //排序后输出

}

(3)输出打印函数

void printf_arr(int arr[], int sz)
{
    for (int i = 0; i < sz; i++)
    {
        printf("%d ", arr[i]);
    }
    putchar('\n');
}

(4)my_sort()函数

void my_sort(void* base, size_t num, size_t size, int(*compar)(const void* e1, const void* e2))
{
    //冒泡排序的趟数,
    int i = 0;
    for (int i = 0; i < num - 1; i++)
    {
        //一趟冒泡排序
        for (int j = 0; j < num - 1 - i; j++)
        {
            if (compar((char*)base + j * size, (char*)base + (j + 1) * size) >0)
            {
                //交换函数
                swap((char*)base + j * size, (char*)base + (j + 1) * size, size);
            }
        }
    }
}

(5)swap()交换函数

void swap(char* buf1, char* buf2, size_t size)
{
    int i = 0;
    for (int i = 0; i < size; i++)
    {
        char tmp = *buf1;
        *buf1 = *buf2;
        *buf2 = tmp;
        buf1++;
        buf2++;
    }
}

(6)compar函数

int my_compar_int(const void*e1,const void*e2)
{
    return *(int*)e1 - *(int*)e2;
}

2.完整代码

//打印数组函数
void printf_arr(int arr[], int sz)
{
	for (int i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}
	putchar('\n');
}
//交换函数
void swap(char* buf1, char* buf2, size_t size)
{
	int i = 0;
	for (int i = 0; i < size; i++)
	{
		char tmp = *buf1;
		*buf1 = *buf2;
		*buf2 = tmp;
		buf1++;
		buf2++;
	}
}
//定义qsort函数
void my_sort(void* base, size_t num, size_t size, int(*compar)(const void* e1, const void* e2))
{
	//冒泡排序的趟数,
	int i = 0;
	for (int i = 0; i < num - 1; i++)
	{
		//一趟冒泡排序
		for (int j = 0; j < num - 1 - i; j++)
		{
			if (compar((char*)base + j * size, (char*)base + (j + 1) * size) >0)
			{
				//交换函数
				swap((char*)base + j * size, (char*)base + (j + 1) * size, size);
			}
		}
	}
}
//int类型conmpar函数
int my_compar_int(const void*e1,const void*e2)
{
	return *(int*)e1 - *(int*)e2;
}
//测试,打印整形数组
void test1()
{
	int arr[] = { 9,8,7,6,5,4,3,2,1,0 };
	//降序排为升序;
	int sz = sizeof(arr) / sizeof(arr[0]);
	printf_arr(arr, sz);
	my_sort(arr, sz, sizeof(arr[0]), my_compar_int);
	printf_arr(arr, sz);

}
int main()
{
	test1();
	return 0;
}

3.打印结果

三,结构体数组排序(按字符串长度进行排列)

1.完整代码

//结构体类型
struct Stu
{
	char name[20]; 
	int age;      
};
//结构体compar函数
int compar_stu_name(const void* e1, const void* e2)
{
	return strcmp(((struct Stu*)e1)->name, ((struct Stu*)e2)->name);
}
//定义qsort函数
void my_sort(void* base, size_t num, size_t size, int(*compar)(const void* e1, const void* e2))
{
	//冒泡排序的趟数,
	int i = 0;
	for (int i = 0; i < num - 1; i++)
	{
		//一趟冒泡排序
		for (int j = 0; j < num - 1 - i; j++)
		{
			if (compar((char*)base + j * size, (char*)base + (j + 1) * size) >0)
			{
				//交换函数
				swap((char*)base + j * size, (char*)base + (j + 1) * size, size);
			}
		}
	}
}
//测试,对结构体类型排序
void test2()
{
	struct Stu arr[] = { {"zhangsan",20},{"lisi",30},{"wangwu",15} };
	int sz = sizeof(arr) / sizeof(arr[0]);
	my_sort(arr, sz, sizeof(arr[0]), compar_stu_name);
	for (int i = 0; i < sz; i++)
	{
		printf("%s %d\n", arr[i].name,arr[i].age);
	}
}

int main()
{
	test2();
	return 0;
}

2.运行结果

  • 10
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

大魔王学编程

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

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

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

打赏作者

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

抵扣说明:

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

余额充值