博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Merge Sort 归并排序
阅读量:6648 次
发布时间:2019-06-25

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

一、基本思想

归并排序是建立在归并操作上的一种有效的排序算法。

该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。

将一个数组分为越来越小的子列表,每个子列表单独进行排序,然后合并形成更大的有序列表。

通过归并子列表元素来合并子列表就是归并排序(Merge Sort)

二、算法描述

1. 将一个列表分割成2个子列表

2. 第1个列表调用索引[first,mid]来定义原始序列的下半部分;

3. 第2个列表调用索引[mid,last]来定义原始序列的上半部分;

4. 这个过程可以生成一个递归调用链,从而将原始列表分隔为越来越小的子列表(半部分列表),直至这些子列表长度为1(停止条件)

5. 以相反的顺序合并这些子列表,会形成越来越大的子列表;

6. 子列表的最后合并对应着第一个递归步骤,并且将原始数组排列为有序状态。

三、示例代码

public class Merge{    public static void MergeSort(int[] arr)    {        // create a temporary array to store partitioned elements        int[] tempArr = (int[])arr.Clone();        // call msort with arrays arr and tempArr along with the index range        msort(arr, tempArr, 0, arr.Length);    }    private static void msort(int[] arr, int[] tempArr, int first, int last)    {        // if the sublist has more than 1 element,continue        if (first + 1 < last)        {            // if the sublist of size 2 or more,call msort()            // for the left and right sublists and then merge the sorted sublists using merge()            int midpt = (first + last) / 2;            msort(arr, tempArr, first, midpt);            msort(arr, tempArr, midpt, last);            // if list is already sorted,just copy from src to dest;            // this is an optimization that results in faster sorts for nearly ordered list            if (((IComparable)arr[midpt - 1]).CompareTo(arr[midpt]) < 0)            {                return;            }            // the element in the ranges[first,mid] and [mid,last] are ordered;            // merge the ordered sublists into an ordered sequence in the range [first,last]            // using the temporary array            int indexA, indexB, indexC;            // set indexA to scan sublist A with range[first,mid]            // and indexB to scan sublist B with range[mid,last]            indexA = first;            indexB = midpt;            indexC = first;            // while both sublists are not exhausted, compare arr[indexA] and arr[indexB];            // copy the smaller to tempArr            while (indexA < midpt && indexB < last)            {                if (((IComparable)arr[indexA]).CompareTo(arr[indexB]) < 0)                {                    tempArr[indexC] = arr[indexA];// copy to tempArr                    indexA++;                }                else                {                    tempArr[indexC] = arr[indexB];// copy to tempArr                    indexB++;                }                // increment indexC                indexC++;            }            // copy the tail of the sublist that is not exhausted            while (indexA < midpt)            {                tempArr[indexC] = arr[indexA];// copy to tempArr                indexA++;                indexC++;            }            while (indexB < last)            {                tempArr[indexC] = arr[indexB];// copy to tempArr                indexB++;                indexC++;            }            // copy the elements from temporary array to original array            for (int i = first; i < last; i++)            {                arr[i] = tempArr[i];            }        }    }}

四、效率分析

稳定

空间复杂度:O(n)

时间复杂度:O(nlog2n)

最坏情况:O(nlog2n)

最好情况:O(nlog2n)

转载地址:http://mruto.baihongyu.com/

你可能感兴趣的文章
screen:一款开源的会话保持软件
查看>>
python计算春节倒计时
查看>>
IOS测试入门必看
查看>>
年末至,思乡浓,致敬北漂(邯郸人有彩蛋)
查看>>
数据库设计文档模板
查看>>
Unix整理笔记-超级无敌常用命令杂谈1-里程碑M6
查看>>
CloudStack4.1.1升级CloudPlatForm4.2.0实践手册
查看>>
Centos安装各种数据分析库,numpy,pandas,matplotlib,seaborn,scipy
查看>>
C#基础知识整理:C#类和结构(3)
查看>>
SharePoint Server 2010 初始化
查看>>
【我眼中的戴尔转型】(四)惠普之道,月亮的脸悄悄地在改变
查看>>
***S 2012 聚合函数 -- 指定分页示例
查看>>
直播疑难杂症排查(3)— 首开慢
查看>>
某公司机房成功搭建openssh server跳板服务器
查看>>
ADT在線互動教學
查看>>
PowerShell 添加 自定义的ScriptProperty 属性
查看>>
Shell一些例子
查看>>
MySQL 可优化的一些参数详解
查看>>
zabbix监控web页面,以及告警配置
查看>>
C#中传值调用和传引用调用的理解
查看>>