使用冒泡排序的思想来模拟实现qsort的功能

目录

qsort功能简介:对任意类型的数组进行排序,如整型数组,结构体数组等。

1.模拟实现整型数组的排序

总体实现思路:

[1.参考qsort函数的参数(我会专门写一个关于qsort函数的理解)。分别为数组首元素的地址,数组元素的个数,数组内每个元素的大小以及一个指针指向的是两个元素的比较函数 。](#1.参考qsort函数的参数(我会专门写一个关于qsort函数的理解)。分别为数组首元素的地址,数组元素的个数,数组内每个元素的大小以及一个指针指向的是两个元素的比较函数 。)

2.根据冒泡排序思路,两个for循环是肯定没问题的,要变的一定是判断何时交换的if判断条件,但是此时,我们只知道首元素地址,但不知道指针类型,所以根本不可以直接解引用,此时我们根据下图进行分析,int类型的数组之间每个元素为4个字节,此时如果使用((char*)base+4)是不是就可以得到第二个元素的地址了,(因为char*类型的指针+1会往后移动一个字节)。而第j个和第(j+1)个是不是也就可以推到了。

2.模拟实现结构体数组的排序

总体思路:与上文大致相同,但是要注意,结构体成员的间接访问符(->),以及strcmp函数(它是专门用来比较字符串的)。


qsort功能简介:对任意类型的数组进行排序,如整型数组,结构体数组等。

1.模拟实现整型数组的排序

代码如下:

cs 复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
//1.交换函数
void Exchange(char* p1, char* p2,int width)
{
	for (int i = 0; i < width; i++)
	{
		int tmp = *p1;
		*p1 = *p2;
		*p2 = tmp;
		p1++;
		p2++;
	}
}

//2.模拟实现排序的冒泡排序框架
void boubble_qsort(int* base, int len , int width , int(*cmp_all)(const void* p1 , const void* p2))
{
	for (int i = 0; i < len - 1; i++)
	{
		for (int j = 0; j < len - 1 - i; j++)
		{
			if ( ((char*)base+j*width - (char*)base + (j+1) * width) > 0)//如果二者相减大于0,则二者进行交换
			{
				//进行交换
				Exchange(((char*)base + j * width), ((char*)base + (j + 1) * width),width);
			}
		}
	}
}

//3.打印函数
void Print(int* p, int len)
{
	for (int i = 0; i < len; i++)
	{
		printf("%d ", *(p + i));
	}
	printf("\n");
}

//4.两个数的比较函数
int cmp_int(const void* p1, const void* p2)
{
	return (*(int*)p1 - *(int*)p2);
}

//5,主函数
int main()
{
	int arr[10] = {9,8,7,6,5,4,3,2,1,0};
	int len = sizeof(arr) / sizeof(arr[0]);
	boubble_qsort(arr, len, sizeof(arr[0]), cmp_int);
	Print(arr, len);
	return 0;
}

总体实现思路:

1.参考qsort函数的参数(我会专门写一个关于qsort函数的理解)。分别为数组首元素的地址,数组元素的个数,数组内每个元素的大小以及一个指针指向的是两个元素的比较函数 。

2.根据冒泡排序思路,两个for循环是肯定没问题的,要变的一定是判断何时交换的if判断条件,但是此时,我们只知道首元素地址,但不知道指针类型,所以根本不可以直接解引用,此时我们根据下图进行分析,int类型的数组之间每个元素为4个字节,此时如果使用((char*)base+4)是不是就可以得到第二个元素的地址了,(因为char*类型的指针+1会往后移动一个字节)。而第j个和第(j+1)个是不是也就可以推到了。

2.模拟实现结构体数组的排序

代码如下:

cs 复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
//1.交换函数
void Exchange(char* p1, char* p2,int width)
{
	for (int i = 0; i < width; i++)
	{
		int tmp = *p1;
		*p1 = *p2;
		*p2 = tmp;
		p1++;
		p2++;
	}
}
//2.模拟实现的冒泡函数框架
void boubble_qsort(int* base, int len , int width , int(*cmp_all)(const void* p1 , const void* p2))
{
	for (int i = 0; i < len - 1; i++)
	{
		for (int j = 0; j < len - 1 - i; j++)
		{
			if ( ((char*)base+j*width - (char*)base + (j+1) * width) > 0)//如果二者相减大于0,则二者进行交换
			{
				//进行交换
				Exchange(((char*)base + j * width), ((char*)base + (j + 1) * width),width);
			}
		}
	}
}

//3.打印函数
void Print(int* p, int len)
{
	for (int i = 0; i < len; i++)
	{
		printf("%d ", *(p + i));
	}
	printf("\n");
}

//4.结构体
struct Stu
{
	char name[20];
	int age;
};

//5.比较函数
int cmp_struct_by_name(const void* p1 ,const void* p2)
{
	return strcmp((((struct Stu*)p1)->name), (((struct Stu*)p2)->name));
}


//6.主函数
int main()
{
	struct Stu s1[3] = { {"zhangsan",20},{"lisi",35},{"wangwu",18} };
	int len1 = sizeof(s1) / sizeof(s1[0]);
	boubble_qsort(s1, len1, sizeof(s1[0]), cmp_struct_by_name);
	Print(arr, len);
	return 0;
}

总体思路:与上文大致相同,但是要注意,结构体成员的间接访问符(->),以及strcmp函数(它是专门用来比较字符串的)。

相关推荐
aaaameliaaa23 分钟前
计算斐波那契数(递归、迭代)(1,1,2,3,5.....)
c语言·开发语言·笔记·算法·排序算法
Jerry29 分钟前
LeetCode 977. 有序数组的平方
算法
金融小师妹40 分钟前
人工智能推演框架:非农降温信号如何重构黄金定价模型
数据结构·人工智能·机器学习·transformer
Turbo正则1 小时前
群论学习入门 | 群论与李群的基本概念
人工智能·学习·算法·抽象代数
sugar__salt1 小时前
手撕字符串算法:反转、回文、验证回文 Ⅱ 完整拆解
javascript·算法·面试·职场和发展
To_OC1 小时前
从一行报错开始,把字符串反转、回文算法连带着包装类一起捋明白
javascript·算法·api
LCG米1 小时前
机器人控制系统与运动规划:从RRT算法到ROS move_base实战
算法·机器人
QiLinkOS1 小时前
第三视觉理解徐玉生与他的商业活动(26)
大数据·c++·人工智能·算法·开源协议
手写码匠2 小时前
手写 LLM 结构化输出引擎 —— 从 JSON Schema 约束到类型安全的数据提取
人工智能·深度学习·算法·aigc
zhiSiBuYu05172 小时前
重排序(Rerank)提升检索准确率实战指南
开发语言·python·算法