归并排序(merging sort): 包含2-路归并排序, 把数组拆分成两段, 使用递归, 将两个有序表合成一个新的有序表.

归并排序(merge sort)的时间复杂度是O(nlogn), 实际效果不如快速排序(quick sort)和堆排序(heap sort),

但是归并排序是稳定排序, 而快速排序和堆排序则不是.

代码:

  1. /*
  2. * main.cpp
  3. *
  4. *  Created on: 2014.6.12
  5. *      Author: Spike
  6. */
  7. /*eclipse cdt, gcc 4.8.1*/
  8. #include <iostream>
  9. #include <algorithm>
  10. #include <iterator>
  11. using namespace std;
  12. /*参数: SR-输入数组, TR-输出数组, i至m:第一段有序, m+1至n:第二段有序*/
  13. void Merge (const std::vector<int> SR, std::vector<int>& TR, int i, int m, int n)
  14. {
  15. int j , k;
  16. for (j=m+1, k=i; i<=m && j<=n; ++k) {
  17. if (SR[i] < SR[j])
  18. TR[k] = SR[i++];
  19. else
  20. TR[k] = SR[j++];
  21. }
  22. if (i<=m)
  23. std::copy((SR.begin()+i), (SR.begin()+m+1), TR.begin()+k);
  24. if (j<=n)
  25. std::copy((SR.begin()+j), (SR.begin()+n+1), TR.begin()+k);
  26. }
  27. /*参数: SR-输入数组, TR-输出数组, s:起始, t:末尾*/
  28. void MSort (const std::vector<int> SR, std::vector<int>& TR, int s, int t)
  29. {
  30. std::vector<int> tempTR(SR.size());
  31. if (s == t)
  32. TR[s] = SR[s];
  33. else {
  34. int m = (s+t)/2; //平分SR, SR[s..m]和SR[m+1..t]
  35. MSort(SR, tempTR, s, m); //前半段
  36. MSort(SR, tempTR, m+1, t); //后半段
  37. Merge(tempTR, TR, s, m, t); //排序
  38. //copy(TR.begin(), TR.end(), ostream_iterator<int>(cout, " "));
  39. //std::cout << std::endl;
  40. }
  41. }
  42. void MergeSort (std::vector<int>& L) {
  43. MSort(L, L, 0, L.size()-1);
  44. }
  45. int main (void)
  46. {
  47. std::vector<int> L = {49, 38, 65, 97, 76, 13, 27, 49};
  48. MergeSort(L);
  49. copy(L.begin(), L.end(), ostream_iterator<int>(cout, " "));
  50. std::cout << std::endl;
  51. return 0;
  52. }

输出:

    1. 13 27 38 49 49 65 76 97

数据结构 - 归并排序(merging sort)的更多相关文章

  1. 数据结构 - 归并排序(merging sort) 具体解释 及 代码

    归并排序(merging sort) 具体解释 及 代码 本文地址: http://blog.csdn.net/caroline_wendy 归并排序(merging sort): 包括2-路归并排序 ...

  2. 归并排序(Merging Sort)

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  3. 小小c#算法题 - 8 - 归并排序 (Merging Sort)

    “归并”的含义是将两个或两个以上的有序序列组合成一个新的有序序列.这个“归并”可以在O(n+m)的数量级上实现,但这同时也需要O(n+m)的空间复杂度.具体为:首先分配一个新的长度为n+m的空序列,然 ...

  4. FZU 1919 -- K-way Merging sort(记忆化搜索)

    题目链接 Problem Description As we all known, merge sort is an O(nlogn) comparison-based sorting algorit ...

  5. 经典排序算法 - 归并排序Merge sort

    经典排序算法 - 归并排序Merge sort 原理,把原始数组分成若干子数组,对每个子数组进行排序, 继续把子数组与子数组合并,合并后仍然有序,直到所有合并完,形成有序的数组 举例 无序数组[6 2 ...

  6. 算法与数据结构基础 - 排序(Sort)

    排序基础 排序方法分两大类,一类是比较排序,快速排序(Quick Sort).归并排序(Merge Sort).插入排序(Insertion Sort).选择排序(Selection Sort).希尔 ...

  7. 连续线性空间排序 起泡排序(bubble sort),归并排序(merge sort)

    连续线性空间排序 起泡排序(bubble sort),归并排序(merge sort) 1,起泡排序(bubble sort),大致有三种算法 基本版,全扫描. 提前终止版,如果发现前区里没有发生交换 ...

  8. Python入门篇-数据结构堆排序Heap Sort

    Python入门篇-数据结构堆排序Heap Sort 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.堆Heap 堆是一个完全二叉树 每个非叶子结点都要大于或者等于其左右孩子结点 ...

  9. 排序算法二:归并排序(Merge sort)

    归并排序(Merge sort)用到了分治思想,即分-治-合三步,算法平均时间复杂度是O(nlgn). (一)算法实现 private void merge_sort(int[] array, int ...

随机推荐

  1. Lingo 做线性规划 - Game Thoery

    Reference: <An Introduction to Management Science Quantitative Approaches to Decision Making, Rev ...

  2. Atitit..组件化事件化的编程模型--(2)---------Web datagridview 服务器端控件的实现原理and总结

    Atitit..组件化事件化的编程模型--(2)---------Web datagridview 服务器端控件的实现原理and总结 1. 服务端table控件的几个流程周期 1 1.1. 确认要显示 ...

  3. paip.判断字符是否中文与以及判读是否是汉字uapi python java php

    paip.判断字符是否中文与以及判读是否是汉字uapi python java php   ##判断中文的原理 注意: 中文与汉字CJKV 的区别..日本,韩国,新加坡,古越南等国家也用汉字,但不是中 ...

  4. MySql 分页

    MySql 分页 由于最近项目需要,于是就简单写了个分页查询.总体而言MySql 分页机制较为简单.数据库方面只需要使用limit即可实现分页.前后台交互就直接用session传了值. 下面就写写具体 ...

  5. 不能返回函数内部new分配的内存的引用

    以前在开发电子秤接口动态库时,曾尝试在用于获取重量的函数外面定义一个字符串指针,然后作为参数传入函数内部,然后在函数内部new,用来输出函数执行过程中发生的错误.但是总是出错,没有找到原因,后来无意中 ...

  6. 新版PHP 7效能實測:Drupal 7能快70%,碎形計算大勝Ruby和Python

    PHP 7才剛在12月3日正式釋出,網頁開發框架Zend公司立刻發表了一份PHP新舊版效能大車拼報告,除了PHP 7和PHP 5.6之外,也把HHVM 3.7版納入一起比較. Zend公司選擇了幾套知 ...

  7. 幾個步驟輕鬆在windows操作系統上搭建GO語言開發環境

    1. 首先下载官方GO語言安装包: https://code.google.com/p/go/wiki/Downloads?tm=2 2. 设置 GOPATH 在任意磁盘根目录新建一个文件夹,名字随意 ...

  8. java代码实现如何获取当前经纬度?(安卓的话可以用GPS取)

    import android.app.Activity; import android.os.Bundle; import android.location.*; import android.con ...

  9. HTTP基本认证(Basic Authentication)的JAVA示例

    大家在登录网站的时候,大部分时候是通过一个表单提交登录信息.但是有时候浏览器会弹出一个登录验证的对话框,如下图,这就是使用HTTP基本认证.下面来看看一看这个认证的工作过程:第一步:  客户端发送ht ...

  10. 安装redis监控

    在修改登录中心的时候,数据存储在redis里面,需要对redis进行监控,使用的是Redis-Live 参考文章: http://www.nkrode.com/article/real-time-da ...