登录 |  注册
首页 >  云计算&大数据 >  经典算法大全 · 实例详解 >  归并排序算法

归并排序算法

归并算法(Merge Algorithm)是一种在计算机科学中广泛使用的算法,特别在排序领域中有着重要的地位。归并操作主要用于将两个或多个有序的子序列合并成一个新的有序序列。

归并排序.jpg

归并排序(Merge Sort)是一个基于归并算法的排序方法,它采用了分治(Divide and Conquer)策略:

  • 分治阶段: 将待排序的序列不断地二等分,直至每个子序列只剩下一个元素,这些单元素的子序列自然都是有序的。

  • 合并阶段: 使用归并操作将相邻的有序子序列合并成一个更大的有序子序列,这一过程递归地进行,直到最后得到一个完全有序的序列。

归并排序的具体步骤包括:

  • 将序列划分为两个子序列,每个子序列可以进一步递归地进行归并排序。

  • 合并两个已排序的子序列:创建一个新的临时数组(或使用额外的空间),从两个子序列的头部开始比较元素,把较小的元素放入临时数组,直到某一个子序列为空,然后将另一个子序列剩余的元素全部复制到临时数组中。

  • 最终将临时数组的内容复制回原数组,完成合并。

以下是一个简单的Java实现归并排序的例子:

public class MergeSort {
    public static void mergeSort(int[] arr, int left, int right) {
        if (left < right) {
            int mid = left + (right - left) / 2;
            
            // 递归地对左右两半进行归并排序
            mergeSort(arr, left, mid);
            mergeSort(arr, mid + 1, right);

            // 合并两个有序的子数组
            merge(arr, left, mid, right);
        }
    }

    private static void merge(int[] arr, int left, int mid, int right) {
        int[] temp = new int[right - left + 1];
        int i = left, j = mid + 1, k = 0;

        // 合并两个子数组,将较小的元素放入temp数组
        while (i <= mid && j <= right) {
            if (arr[i] <= arr[j]) {
                temp[k++] = arr[i++];
            } else {
                temp[k++] = arr[j++];
            }
        }

        // 将剩余的元素填充进temp数组
        while (i <= mid) {
            temp[k++] = arr[i++];
        }
        while (j <= right) {
            temp[k++] = arr[j++];
        }

        // 将temp数组中的元素复制回原数组
        for (i = left; i <= right; i++) {
            arr[i] = temp[i - left];
        }
    }

    // 示例:调用归并排序函数
    public static void sort(int[] arr) {
        mergeSort(arr, 0, arr.length - 1);
    }
}

此算法的时间复杂度为O(n log n),空间复杂度为O(n),其中n代表待排序数组的元素个数。尽管空间消耗较大,但由于其稳定性以及对于大数据集的良好性能,归并排序在许多场合下具有很高的实用价值。

上一篇: 希尔排序算法
下一篇: 桶排序算法
推荐文章
  • MD5(Message-DigestAlgorithm5)是一种广泛使用的散列函数(哈希函数),由美国密码学家罗纳德·李维斯特(RonaldL.Rivest)在1991年设计。MD5的作用是对任意长度的信息生成一个固定长度(128位,即32个十六进制字符)的“指纹”或“消息摘要”,并且几乎不可能找到
  • 循环冗余校验(CyclicRedundancyCheck,CRC)是一种用于检测数据传输和存储过程中发生错误的技术,属于一种基于数学原理的错误检测编码(ErrorDetectionCoding)方法。它通过在原始数据上附加一个固定长度的校验码,使得接收端可以通过同样的计算规则对收到的数据进行校验,确
  • AES(AdvancedEncryptionStandard)是一种广泛使用的对称密钥加密算法,它是美国国家标准与技术研究院(NIST)于2001年制定的加密标准,用于替代原有的DES(DataEncryptionStandard)。AES算法以其高效性、安全性和可靠性而著称,在众多应用领域中被广泛
  • RSA(Rivest-Shamir-Adleman)是一种广泛应用的非对称加密算法,由RonRivest、AdiShamir和LenAdleman在1977年提出。其安全性基于数学上的大数因子分解难题,即对于足够大的两个素数p和q而言,已知它们的乘积很容易,但想要从这个乘积中恢复原始的素数则异常困难
  • 最小生成树(MinimumSpanningTree,MST)是一种图论算法,用于在一个带权重的无向连通图中找到一棵包括所有顶点且总权重尽可能小的树。常见的最小生成树算法有两种:Prim算法和Kruskal算法。Prim算法原理:Prim算法是一种贪心算法,它从图中的一个顶点开始,逐步增加边,每次都添
  • 关于最短路径算法的Java实现,这里简述一下几种常用的算法及其基本原理,并给出一个Dijkstra算法的基本实现框架。Dijkstra算法(适用于无负权边的图)Dijkstra算法用于寻找图中一个顶点到其他所有顶点的最短路径。它维护了一个距离表,用来存储从源点到各个顶点的已知最短距离,并且每次都会选
学习大纲