对任意类型数都可以排序的函数: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;
}
相关推荐
算AI7 小时前
人工智能+牙科:临床应用中的几个问题
人工智能·算法
我不会编程5557 小时前
Python Cookbook-5.1 对字典排序
开发语言·数据结构·python
似水এ᭄往昔8 小时前
【C语言】文件操作
c语言·开发语言
owde8 小时前
顺序容器 -list双向链表
数据结构·c++·链表·list
第404块砖头8 小时前
分享宝藏之List转Markdown
数据结构·list
hyshhhh9 小时前
【算法岗面试题】深度学习中如何防止过拟合?
网络·人工智能·深度学习·神经网络·算法·计算机视觉
蒙奇D索大9 小时前
【数据结构】第六章启航:图论入门——从零掌握有向图、无向图与简单图
c语言·数据结构·考研·改行学it
A旧城以西9 小时前
数据结构(JAVA)单向,双向链表
java·开发语言·数据结构·学习·链表·intellij-idea·idea
杉之10 小时前
选择排序笔记
java·算法·排序算法
烂蜻蜓10 小时前
C 语言中的递归:概念、应用与实例解析
c语言·数据结构·算法