归并排序菜鸟入门
发布日期:2021-06-30 10:11:49
浏览次数:3
分类:技术文章
本文共 1771 字,大约阅读时间需要 5 分钟。
归并排序是一种稳定快速地排序方法,该算法采用分治法的一个应用。也许这个名字刚听起来不是很好听,我一直将他说成是并归排序哈哈。
为什么会叫归并排序呢?不知道大家有没有这个疑问?
归并排序的整体思路就是先归后并,归是递归,将数组分为两部分,然后将左右两部分再分别递归分配咯,并就是合并,把分开的各个数组依次合并,最终完成一个无序数组的排序啦。
来我们再看看归并排序的基本步骤:
1.首先将数组分为两两一组
2.相邻进行比较合并。
举例才是王道:
请看
{2,8,6,9,4,7,3,9,1}
首先进行分组同时进行比较:
{2,8},{6,9},{4,7},{3,9},{1} 比较 4 次{2,6,8,9},{3,4,7,9},{1} 比较6次
{2,3,4,6,7,8,9,9},{1} 比较7次
{1,2,3,4,6,7,8,9,9,} 比较一次
完毕!
代码才是王道了,下面是C++的案例:
/*实际上使用的是C,不是C++*/#include#include #include using namespace std;void Merge(int sourceArr[],int tempArr[],int startIndex,int midIndex,int endIndex){ //设置前一个数组的首元素i,后一个数组的首元素j,k为拷贝原来大小的新数组的首元素 int i = startIndex,j = midIndex+1,k = startIndex; //当两个数组元素都不未读取完成 while(i!=midIndex+1 &&j!=endIndex+1) { if(sourceArr[i] > sourceArr[j]) tempArr[k++] = sourceArr[j++]; else tempArr[k++] = sourceArr[i++]; } //当j数组元素读取完成,i数组剩余元素直接添加到后面 while(i != midIndex +1) tempArr[k++] = sourceArr[i++]; //当i数组元素读取完成,j数组剩余元素直接添加到后面 while(j != endIndex +1) tempArr[k++] = sourceArr[j++]; //将排好导入的新数组里的内容复制到原来的数组 for(i=startIndex;i<=endIndex;i++) sourceArr[i] = tempArr[i];}void MergeSort(int sourceArr[], int tempArr[], int startIndex,int endIndex){ int midIndex; //判断是否递归 if(startIndex < endIndex) { //midIndex是前后两个相邻的数组的前一个数组最后的一个元素 midIndex= (startIndex + endIndex)/2; //递归前半部分 MergeSort(sourceArr,tempArr,startIndex,midIndex); //递归后半部分 MergeSort(sourceArr,tempArr,midIndex+1,endIndex); //归并的合并阶段啦 Merge(sourceArr,tempArr,startIndex,midIndex,endIndex); }}int main(){ int a[10] = {2,3,6,5,9,10,20,3,12,6}; int i ,b[10]; MergeSort(a,b,0,9); for(i=0;i<10;i++) cout< <<" ";}
转载地址:https://islet.blog.csdn.net/article/details/75472966 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
路过,博主的博客真漂亮。。
[***.116.15.85]2024年04月23日 18时30分46秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
《知识图谱》阅读笔记(六)
2019-04-30
【NLP学习笔记】中文分词(Word Segmentation,WS)
2019-04-30
【NLP学习笔记】词性标注(Part-of-speech Tagging, POS)
2019-04-30
《知识图谱》阅读笔记(七)
2019-04-30
《知识图谱》阅读笔记(九)
2019-04-30
【超越白皮书7】你需要知道关于ETH2.0的几个事实
2019-04-30
超越白皮书8:穿云而过的闪电网络
2019-04-30
AMM做市无常损失对冲分析系列(一)—— 损益及期权对冲模型构建
2019-04-30
JS中document对象和window对象有什么区别
2019-04-30
【python练习题】遍历1
2019-04-30
【matlab】显示图片且下方显示文字
2019-04-30
关于greater<int>以及类模板的一些理解
2019-04-30
对于时间复杂度的通俗理解
2019-04-30
如何输入多组数据并输出每组数据的和?
2019-04-30
基于CentOS 7的Linux常用命令行命令
2019-04-30
行阶梯型矩阵
2019-04-30
信号量机制
2019-04-30
临界资源与临界区
2019-04-30
matlab中uint8,double,im2double和im2uint8的区别
2019-04-30