排序算法之五——归并排序
来源:互联网 发布:nasa 数据库 故障预测 编辑:程序博客网 时间:2024/06/05 14:38
转载请标明出处:http://blog.csdn.net/xx326664162/article/details/51593685 文章出自:薛瑄的博客
你也可以查看我的其他同类文章,也会让你有一定的收货!
归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。
首先考虑下如何将将二个有序数列合并。这个非常简单,只要从比较二个数列的第一个数,谁小就先取谁,取了后就在对应数列中删除这个数。然后再进行比较,如果有数列为空,那直接将另一个数列的数据依次取出即可。
递归法
原理如下(假设序列共有n个元素):
- 将序列每相邻两个数字进行归并操作,形成floor(n/2)个序列,排序后每个序列包含两个元素
- 将上述序列再次归并,形成 floor(n/4)个序列,每个序列包含四个元素
- 重复步骤2,直到所有元素排序完毕
//将有二个有序数列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; 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]; } 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 a[], int n) { int *p = new int[n]; if (p == NULL) return false; mergesort(a, 0, n - 1, p); delete[] p; return true; }
归并排序的效率是比较高的,设数列长为N,将数列分开成小数列一共要logN步,每步都是一个合并有序数列的过程,时间复杂度可以记为O(N),故一共为O(N*logN)。因为归并排序每次都是在相邻的数据中进行操作,所以归并排序在O(N*logN)的几种排序方法(快速排序,归并排序,希尔排序,堆排序)也是效率比较高的。
http://blog.csdn.net/morewindows/article/details/6678165
https://zh.wikipedia.org/wiki/%E5%BD%92%E5%B9%B6%E6%8E%92%E5%BA%8F
0 0
- 排序算法之五——归并排序
- 排序算法五—归并排序
- 排序算法之五 归并排序
- 算法——排序之归并排序
- 算法——排序之归并排序
- 排序算法(五)--归并排序
- 排序算法(五) - 归并排序
- 【排序算法五】归并排序
- 【啊哈!算法】之五、归并排序
- 排序算法—归并排序
- 排序算法—归并排序
- 【数据结构与算法】排序算法之五:归并排序
- 算法之旅——归并排序
- 【算法之家】——归并排序
- 基础算法系列(五)——归并排序
- 经典排序算法之——归并排序
- 排序算法总结之——归并排序
- 排序算法之 —— 归并排序(六)
- 数据库控制文件中的SCN详解
- 面试中常见链表问题4:删除链表中重复元素1
- 快速理解Docker - 容器级虚拟化解决方案
- ViewPager实现每隔两秒自动切换图片 (再续)
- 苹果IOS开发者账号总结
- 排序算法之五——归并排序
- c++常用字符串操作函数
- Cisco交换机/路由器日志配置远程Syslog采集
- 什么是POW和POS,二者区别联系?
- range——input新属性,可拖动的进度条
- Jsp注意事项汇总
- 报错:Cannot change deployment state from ERROR to REDEPLOYING
- 【指南】本地如何搭建IPv6环境测试你的APP
- Linux 本地文件系统挂载的目录扩容