c---冒泡排序模拟qsort
创始人
2024-05-29 21:23:55
0

一、冒泡排序

二、冒泡排序优化排各种类型数据

文章目录

  • 一、冒泡排序
    • 二、冒泡排序优化排各种类型数据


冒泡排序

冒泡排序原理:两两相邻元素进行比较
在这里插入图片描述
在这里插入图片描述

初级版

void bulle_sort(int* a, int sz)
{int i = 0;for (int i = 0; i < sz-1; i++){int j = 0; for (j = 0; j < sz - 1 - i; j++){if (a[j] > a[j+1]){int tmp = a[j];a[j] = a[j + 1];a[j + 1] = tmp;}}}
}

这是冒泡排序初级版,不管其原内容是否有序都会进行比较,如果原内容原本就是有序的,再每个都进行比较效率就会低下,那么这时候可以改进一下,想一个标记变量来记录是否有序,如int
falg = 0; 如果无序的情况下falg会变为1,有序的情况下falg保持0不变,如果一趟下来falg 为0
不变,那么就是有序的就不用再比较后面趟数了,这样使其在有序的情况下时间复杂度为O(n),大大提高了效率

改进版

void bulle_sort(int* a, int sz)
{int i = 0;int falg = 0;for (int i = 0; i < sz-1; i++){int j = 0; for (j = 0; j < sz - 1 - i; j++){if (a[j] > a[j+1]){int tmp = a[j];a[j] = a[j + 1];a[j + 1] = tmp;falg = 1;}}if (falg == 0){break;}}
}

冒泡排序优化排各种类型数据
上面冒泡排序可以发现只能够排序整形
在这里插入图片描述
那要是我们想利用冒泡来排其他不同类型应该如何实现呢?这里就引入c语言里的一个库函数qsort(),在cplusplus上搜索qosrt

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

可以发现这是一个排序函数,且qsort函数有四个参数,void * base目标数组,待排序的起始地址,size_t num待排序数组大小,size_t表示无符号类型,由于数组大小不可能为负数,因此设置为size_t更为合适,size_t size,数组中每个元素是多少字节,其实就是每个元素是什么类型
在这里插入图片描述

int (*compar)(const void*,const void*)

这是一个函数指针,是比较函数的函数指针,而comper实现的是比较功能,
在这里插入图片描述
比较函数在这里插入图片描述

由于比较类型不知道是什么类型的,因此用void*,这里这个设计十分合理,void*,void*存的是要比较两个元素的地址,是因为设计者在设计时不知道我们要比较什么类型的,因为void*指针可以接收任意类型变量的地址。comper函数返回类型为in类型,第一个比第二个于返回1,相等返回0,小于返回-1


qsort函数运用

int comper(const void* s1, const void* s2)
{return *((int*)s1) - *((int*)s2);//由于我们自己使用时知道了是什么类型,因此强转为该类型就可,//然后再对其解引用就可以相互进行比较了
}
int main()
{int arr[] = { 9,8,7,6,5,4,3,2,1 };int sz = sizeof(arr) / sizeof(arr[0]);//bulle_sort(arr, sz);qsort(arr, sz, sizeof(arr[0]), comper);for (int i = 0; i < sz; i++){printf("%d ", arr[i]);}printf("\n");return 0;
}

在这里插入图片描述

可以发现出了警告是qsort未定义,这是因为没有包含它所需的头文件

在这里插入图片描述

可以往下翻找到它该用什么头文件
以qsort排序结构体

#include
typedef struct Stu
{char name[20];int age;
}Stu;
int comper_stu_by_name(const void* s1, const void* s2)
{//按照名字比较,两个字符串比较是不能直接相减,用库函数strcmp进行比较//强制类型转换为结构体指针,然后再->找到结构体成员变量namereturn strcmp(((Stu*)s1)->name , ((Stu*)s2)->name);//由于我们自己使用时知道了是什么类型,因此强转为该类型就可,//得到其地址再对其解引用就可以相互进行比较了
}int main()
{Stu s[3] = { {"zhangsan",20},{"wangwu",30},{"lisi",50} };qsort(s, sizeof(s)/sizeof(s[0]), sizeof(s[0]), comper_stu_by_name);for (int i = 0; i < sizeof(s)/sizeof(s[0]); i++){printf("%s %d\n", s[i].name, s[i].age);}
}

在这里插入图片描述
strcmp比较字符串函数
在这里插入图片描述
在这里插入图片描述

strcmp返回类型为int
qsort可以实现任意类型的数据的排序;

以冒泡模拟qsort

//比较时需要比较什么类型自己可以定义,然后强转
//需要排不同类型只需要在这里更改就可以了
int comper(void* s1, void* s2)
{return *((int*)s1) - *((int*)s2);
}void swap(char* buf1, char* buf2, int width)
{int i = 0;//width是数组中每个元素的字节大小,其实以我们来看,知道width就可以知道是什么类型,for (i = 0; i < width; i++){//将每个字节都交换char tmp = *buf1;*buf1 = *buf2;*buf2 = tmp;buf1++;buf2++;}
}//与qsort函数内部一致
//比较类型不明确,所有void*
void bulle_qsort( void* a, size_t sz, size_t width, int (*comper)(const void* s1, const void* s2))
{size_t i = 0;int falg = 0;for (int i = 0; i < sz-1; i++){size_t j = 0; for (j = 0; j < sz - 1 - i; j++){if (comper((char*)a+j*width,(char*)a+(j+1)*width)>0)//实现比较,交换,且由于不知道要比较什么类型,,那么我们只有使用偏移量比较{swap((char*)a + j * width, (char*)a + (j + 1) * width, width);//由于不知道类型,那么就交换每个字节,把每个元素大小传过去falg = 1;}}if (falg == 0){break;}}
}int main()
{int a[] = { 9,8,7,6,5,4,3,2,1 };int sz = sizeof(a) / sizeof(a[0]);//这里可以排任意类型的数据,我这里以整形数组模拟bulle_qsort(a, sizeof(a) / sizeof(a[0]), sizeof(a[0]), comper);for (int i = 0; i < sz; i++){printf("%d ", a[i]);}return 0;
}

在这里插入图片描述
冒泡模拟实现qsort就到这里了,有兴趣的小伙伴可以区试试其他类型的排序吧

上一篇:Feature并行执行程序

下一篇:Spark DPP

相关内容

热门资讯

小学课文叶公好龙的意思是什么 小学课文叶公好龙的意思是什么叶公好龙是一句成语,讲述了叶公爱龙成癖,被天上的真龙知道后,便从天上下降...
完美世界前传图一图二图三的问题... 完美世界前传图一图二图三的问题?我是电二龙现的,101魔尊,图我都开完了,图一可进 千年前天泪之城图...
声开头的四字成语大全 声开头的四字成语大全声开头的四字成语大全 :声色俱厉、声如洪钟、声泪俱下、声情并茂、声东击西、声嘶力...
网络时代消费者心理特征和行为特... 网络时代消费者心理特征和行为特征是怎样的由于它能够提供丰富的商品信息,突破时空的限制,具有低廉的价格...
人生如梦,后面一句是什么 人生如梦,后面一句是什么人生如梦 一樽还酹江月人生如梦,需及时醒来,面对现实一樽还酹江月
求青梅竹马的小说 求青梅竹马的小说总是推的我都看过,多推点吧《夏有乔木,雅望天堂》感人死呢!!!!玄幻小说中有很多
想你第15集里面尹恩惠用的彩笔... 想你第15集里面尹恩惠用的彩笔是什么牌子的?这是马克笔 不管什么牌子效果都一样、和普通彩笔不同的就是...
焉栩嘉被痛斥劈腿背叛,情感失格... 焉栩嘉被痛斥劈腿背叛,情感失格的偶像算劣迹艺人吗?我认为情感失格的偶像应该就算是劣迹艺人人,因为他们...
求异界类似 {异界逍遥公}!和... 求异界类似 {异界逍遥公}!和幻神这样的! 或都市类的像 {龙啸九天-人界风云篇}!!主角蓝玉!我来...
我是从教师转行到财产保险公司做... 我是从教师转行到财产保险公司做保险营销员的,是个到公司快一年的新人,现在急求一份年终总结啊?manm...
改写人生是什么意思? 改写人生是什么意思?就是完全打破以往的人生规划,迎接一个不一样的人生。
找一本主角牙口特别好的小说? 找一本主角牙口特别好的小说?完美世界吗?
无双无对无法比打一数字? 无双无对无法比打一数字?无双无对无法比的数字是0。因为两个O仍是O。
一切都为了生活,那生活又为了什... 一切都为了生活,那生活又为了什么?生活就是你的一切,生活?生存活着!你的所有的努力只是为了活着,为了...
喜欢安静的人是什么性格 喜欢安静的人是什么性格喜欢安静的人通常本身也是比较文静的人,这类人的性格会属于内敛,内向型的。内向、...
哪个播放器能看《一生一世》 哪个播放器能看《一生一世》不好看,暴风影音就有哇如果有关视频的格式是播放器支持的都能看或播放
心里莫名的悸动是什么? 心里莫名的悸动是什么?心里老是莫名的悸动 搞不懂耶失眠、健忘、眩晕、耳鸣等并存,凡各种原因引起心脏搏...
怎样训犬 怎样训犬受训犬是指接受训练的犬。受训犬一般要求除符合本品种的特征外,还应注意:(1)体形外貌。机体各...
天为什么会黑? 天为什么会黑?这是因为地球自转造成的日月更替。地球绕太阳是公转,而在公转的同时地球也在自转。当地球自...
为什么前男友屏蔽朋友圈不让我看... 为什么前男友屏蔽朋友圈不让我看,但是又不删除我?为什么会这样啊都已经让对方变成前任啦!还纠结这些干嘛...