zoukankan      html  css  js  c++  java
  • 归并排序(MergeSort)

    //版权所有 Anders06  于2007年10月25日


    归并排序(Merge Sort)是利用"归并"技术来进行排序。归并是指将若干个已排序的子文件合并成一个有序的文件。
    1、基本思想
    1 分治法的基本思想
    分治法的基本思想是:将原问题分解为若干个规模更小但结构与原问题相似的子问题。递归地解这些子问题,然后将这些子问题的解组合为原问题的解。

    2 归并排序的基本基本步骤
      设两个有序的子文件(相当于输入堆)放在同一向量中相邻的位置上:R[low..m],R[m+1..high],先将它们合并到一个局部的暂存向量R1(相当于输出堆)中,待合并完成后将R1复制回R[low..high]中。

    •   分解: 讲n个元素分成n/2 个元素的子序列
    •   解决: 用合并并排序对两个子序列递归地排序    (在对子序列排序时,长度为1时递归结束)
    •   合并: 合并两个已经排好序的子列序以得到排序结果  

        以扑克牌为例, 假设有两堆牌面朝上地放在桌上,每一堆都是排好序的,最小的牌在最上面。我们希望将两堆牌合并成升序的一堆牌。基本步骤包括在面朝上的两堆牌中,选择顶上两张较小的一张,将其取出放入到输出堆,重复此动作,知道有一堆为空为止,然后吧另一堆所剩下的牌面朝下放入到输出堆即可。 合并排序的时间为 O(n).

    2、 算法分析
    1)时间复杂度
        Merge过程运行的时间为O(n), 而我们总共分了lgn + 1(n为偶数的时候应该为lgn吧, 数学好久没读,头脑不好用咯),因此总的执行实际为nlgn + n,复杂度为 O(nlgn)
    2)空间复杂度
        O(n)
    3)稳定性
        为稳定算法

    C#实现的MergeSort

    MergeSort

    参考资料

    •     <<算法导论>>
  • 相关阅读:
    椭圆形 上传图片预览 image preview (未整理版本)
    canvas学习笔记03:简单脉冲效果
    canvas学习笔记02:饼图&柱状图
    canvas学习笔记01:Math.sin & Math.cos
    java jdk 随机数阻塞问题
    家政/保洁 平台设计
    Lock和synchronized
    jvm 中java new 对象顺序
    Java 多线程原理
    java ftp上传下载,下载文件编码设置
  • 原文地址:https://www.cnblogs.com/anders06/p/937560.html
Copyright © 2011-2022 走看看