博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
让我们来谈谈合并排序算法
阅读量:5157 次
发布时间:2019-06-13

本文共 1647 字,大约阅读时间需要 5 分钟。

转载请注明出处:http://blog.csdn.net/ruoyunliufeng/article/details/27570953      

       归并操作(merge),也叫归并算法,指的是将两个已经排序的序列合并成一个序列的操作。归并排序算法依赖归并操作。

一.归并排序算法

/****************************************************************版权全部 (C)2014,公司名称。

* *文件名:归并排序法 *内容摘要:无 *其他说明:无 *当前版本号:V1.0 *作 者:若云流风 *完毕日期:2014.5.29 ***************************************************************/ #include <stdio.h> #include<stdlib.h> #define N 8 void disp(void); int a[N]={2,1,4,3,6,5,8,7}; //将有二个有序数列a[first...mid]和a[mid...last]合并。 void mergearray(int a[], int first, int mid, int last, int temp[]) { int i = first, j = mid + 1; int m = mid, n = last; int k = 0; printf("\n%d,%d,%d", i,m,n ); //打印first,mid,last while (i <= m && j <= n) { if (a[i] <= a[j]) temp[k++] = a[i++]; else temp[k++] = a[j++]; } while (i <= m) temp[k++] = a[i++]; while (j <= n) temp[k++] = a[j++]; for (i = 0; i < k; i++) a[first + i] = temp[i]; disp(); //打印每次合并完的数组 } /*递归的进行分解。然后合并*/ void mergesort(int a[], int first, int last, int temp[]) { if (first < last) { int mid = (first + last) / 2; mergesort(a, first, mid, temp); //左边有序 mergesort(a, mid + 1, last, temp); //右边有序 mergearray(a, first, mid, last, temp); //再将二个有序数列合并 } } //归并排序 bool MergeSort() { int *p; p = (int *)malloc(N * sizeof(int)); //为了分配暂时数组 if(p!=NULL) { mergesort(a, 0, N - 1, p); free(p); } else return false; } /*输出函数*/ void disp(void) { int i; // printf("\n排序结果: \n"); printf("\n\n"); for(i=0;i<N;i++) { printf("%d", a[i]); printf(" "); } } int main(void) { MergeSort(); //归并排序 //disp(); return 0; }

二.算法会说话

1.输出结果

2.整体过程分析

3.数组合并分析

如今以为第三个输出为例来说明数组是怎样合并的:

版权声明:本文博客原创文章。博客,未经同意,不得转载。

转载于:https://www.cnblogs.com/gcczhongduan/p/4616800.html

你可能感兴趣的文章
11.28.cookie
查看>>
Java中对List集合排序的两种方法
查看>>
BeanShell简介
查看>>
python字符串操作
查看>>
MySQL学习之备份
查看>>
不同程序语言的注释和变量要求
查看>>
语言基础(9):static, extern 和 inline
查看>>
windows linux—unix 跨平台通信集成控制系统
查看>>
【编程练习】复习一下树的遍历
查看>>
邮件和短信验证码
查看>>
(转)Android studio 使用心得(五)—代码混淆和破解apk
查看>>
构建之法阅读笔记03
查看>>
ES5_03_Object扩展
查看>>
Apache-ab 接口性能测试
查看>>
EF 4.1 Code First Walkthrough
查看>>
常用MySQL语法
查看>>
007API网关服务Zuul
查看>>
bzoj 2600: [Ioi2011]ricehub
查看>>
iOS __strong __weak @Strongify @Weakify
查看>>
thinkphp引入PHPExcel类---thinkPHP类库扩展-----引入没有采用命名空间的类库
查看>>