对任意类型数都可以排序的函数:qsort函数

之前我们学习过冒泡排序:

c 复制代码
int main()
{
	int arr[] = { 9,7,8,6,5,4,3,2,1,0 };
	int sz = sizeof(arr)/sizeof(arr[0]);
	int i = 0;
	for (i = 0; i < sz-1; i++) {

		int j = 0;
		for (j = 0; j < sz-1-i; j++) {
			if (arr[j] > arr[j + 1])
			{
				int temp = 0;
				temp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = temp;
			}
		}
	}
	for (i = 0; i < sz; i++)
	{
		printf("%d", arr[i]);
	}
	return 0;
}

可以看出这样的排序方法只适用于整形类型的数

那么是否有一种排序可以满足所有类型都适用的排序呢?

qsort函数排序

应用:

在这里需要补充一下void* 类型的指针

c 复制代码
void in_mp(const void* p1, const void* p2)
{
    return(*(int*) p1 - *(int*)p2);
}
void print(int arr[], int sz)
{
    int i = 0; 
    for (i = 0; i < sz; i++)
    {
        printf("%d", arr[i]);
    }
}
void test1()
{
    int arr[] = { 9,6,7,8,5,3,4,2,1,0 };
    int sz = sizeof(arr) / sizeof(arr[0]);
    qsort(arr, sz, sizeof(arr[0]), in_mp);
    print(arr ,sz);
}
int main()
{
    test1();
    return 0;
   
}

当然qsort函数排序既然可以实现任意类型,那么我们换几个类型试一下;
结构体类型

c 复制代码
struct stu
{
	char name[20];
	int age;
};
void com_in(const void* p1, const void* p2)
{
	return ((struct stu*)p1)->age - ((struct stu*)p2)->age;
}
void print(struct stu arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%s %d ",arr[i].name, arr[i].age);
	}
}
void test2()
{
	
	struct stu arr[] = { {"zhangsan",20},{"lisi",39},{"lihua",28} };
	int sz = sizeof(arr) / sizeof(arr[0]);
	qsort(arr, sz, sizeof(arr[0]), com_in);
	print(arr, sz);
}
int main()
{
	test2();
	return 0;
}


用冒泡排序的思想实现一个功能类似于qsort函数的排序

首先我们先讲一下qsort函数的原理

然后我们用冒泡排序的思想来改造

所以我们要自己创造一个qsort排序函数就要自己写一个可以排序任意类型数据的函数

我们用冒泡排序的思想来改造,就要解决一下问题

问题一

解决后:

问题2

解决:

代码:

c 复制代码
//测试整形类型的的排序
void print(int arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%d", arr[i]);
	}
}
int in_mp(const void* p1, const void* p2)
{
	return(*(int*)p1 - *(int*)p2);

}
tmp(char* put1, char* put2, int size)
{
	int i = 0;
	int temp = 0;
	for (i = 0; i < size; i++)
	{
		 temp = *put1;
		*put1 = *put2;
		*put2 = temp;
		put1++;
		put2++;
		
	}
}
void bobble_sort(void* pa,int sz,int size,int(*p)(const void*,const void*))
{
	int i = 0;
	for (i = 0; i < sz - 1; i++) {

		int j = 0;
		for (j = 0; j < sz - 1 - i; j++)
		{
           //把每一趟的两个对数传给In_mp函数如果大于0,升序的话就要交换
			if (p((char*)pa + j * size, (char*)pa + (j + 1) * size) > 0) 
			{
           //交换
				tmp((char*)pa + j * size, (char*)pa + (j + 1) * size, size);
				
			}
		}
	}
}
void test1()
{
	int arr[] = { 9,7,8,6,5,4,3,2,1,0 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	bobble_sort(arr,sz,sizeof(arr[0]),in_mp);
	print(arr, sz);
}
int main()
{
	test1();
	return 0;
}

也可以测试结构体类型

c 复制代码
tmp(char* put1, char* put2, int size)
{
	int i = 0;
	int temp = 0;
	for (i = 0; i < size; i++)
	{
		 temp = *put1;
		*put1 = *put2;
		*put2 = temp;
		put1++;
		put2++;
		
	}
}
void bobble_sort(void* pa,int sz,int size,int(*p)(const void*,const void*))
{
	int i = 0;
	for (i = 0; i < sz - 1; i++) {

		int j = 0;
		for (j = 0; j < sz - 1 - i; j++)
		{
           //把每一趟的两个对数传给In_mp函数如果大于0,升序的话就要交换
			if (p((char*)pa + j * size, (char*)pa + (j + 1) * size) > 0) 
			{
           //交换
				tmp((char*)pa + j * size, (char*)pa + (j + 1) * size, size);
				
			}
		}
	}
}



//void test1()
//{
//	int arr[] = { 9,7,8,6,5,4,3,2,1,0 };
//	int sz = sizeof(arr) / sizeof(arr[0]);
//	bobble_sort(arr,sz,sizeof(arr[0]),in_mp);
//	print(arr, sz);
//}
struct stu
{
	char name[20];
	int age;
};

int com_in(const void* p1, const void* p2)
{
	return ((struct stu*)p1)->age - ((struct stu*)p2)->age;
}
void print(struct stu arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%s %d ", arr[i].name, arr[i].age);
	}
}
void test2()
{

	struct stu arr[] = { {"zhangsan",20},{"lisi",39},{"lihua",28} };
	int sz = sizeof(arr) / sizeof(arr[0]);
	bobble_sort(arr, sz, sizeof(arr[0]), com_in);
	print(arr, sz);
}
int main()
{
	test2();
	return 0;
}
相关推荐
aini_lovee3 分钟前
WSN 四大经典无需测距定位算法
算法
人道领域3 分钟前
【LeetCode刷题日记】掌握二叉树遍历:栈实现的三种绝妙方法
算法·leetcode·职场和发展
北冥湖畔的燕雀4 分钟前
深入解析Linux信号处理机制
算法
阿Y加油吧12 分钟前
二刷 LeetCode:动态规划经典双题复盘
算法·leetcode·动态规划
上弦月-编程27 分钟前
C语言指针超详细教程——从入门到精通(面向初学者)
java·数据结构·算法
莫等闲-30 分钟前
代码随想录一刷记录Day44——leetcode1143.最长公共子序列 53. 最大子序和
数据结构·c++·算法·leetcode·动态规划
生成论实验室30 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第七篇:社会与情感关系——连接、表达与共鸣
人工智能·算法·架构·交互·创业创新
承渊政道33 分钟前
【动态规划算法】(背包问题经典模型与解题套路)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
weixin_4217252644 分钟前
2026年C/C++/C#全解析:底层语言的进化与场景抉择,选错直接掉队
c语言·c++·c·编程语言·技术选择
yyy(十一月限定版)1 小时前
数电1对应latex代码
算法