归并排序的简单实现

一、排序过程

分为两个大步骤,分解和合并

分解

找到mid,然后分解即可,直到 left == right

合并

合并的思路是把每个小组比较后放入一个新的临时数组里,然后再赋值即可

二、代码实现

java 复制代码
    public static void mergeSort(int[] arr) {
        mergeSortTmp(arr,0,arr.length - 1);
    }
    //分解
    private static void mergeSortTmp(int[] arr, int left, int right) {
        if(left >= right) return;
        int mid = (left + right) / 2;
        mergeSortTmp(arr, left, mid);
        mergeSortTmp(arr, mid + 1, right);
        merge(arr,left,mid,right);
    }
    //合并
    private static void merge(int[] arr, int left, int mid, int right) {
        int[] tmp = new int[right - left + 1];
        int k = 0;
        int s1 = left;
        int s2 = mid + 1;
        while(s1 <= mid && s2 <= right) {
            if(arr[s1] >= arr[s2]){
                tmp[k++] = arr[s2++];
            }else{
                tmp[k++] = arr[s1++];
            }
        }
        while(s1 <= mid){
            tmp[k++] = arr[s1++];
        }
        while(s2 <= right){
            tmp[k++] = arr[s2++];
        }
        for(int i = 0;i < k;i++){
            arr[left+i] = tmp[i];
        }
    }

**arrs1 >= arrs2**其实 换成 > ,结果也是一样的。但是如果真的出现向相等的情况,使用 > 的话,代码会多执行,从效率上考虑,选择 >= 时比较好的

三、非递归实现代码

java 复制代码
    public static void mergeSortNor(int[] arr) {
        int gap = 1;
        while(gap < arr.length){
            for(int i = 0;i < arr.length;i = i + gap * 2){
                int left = i;
                int mid = left + gap - 1;
                if(mid >= arr.length){
                    mid = arr.length - 1;
                }
                int right = mid + gap;
                if(right >= arr.length){
                    right = arr.length - 1;
                }
                merge(arr,left,mid,right);
            }
            gap *= 2;
        }
    }

在上面代码中加入这个方法即可,将分组的形式转变成以gap分组的形式进行

四、归并的特性

  1. 归并的缺点在于需要O(N)的空间复杂度,归并排序的思考更多的是解决在磁盘中的外排序问题。

  2. 时间复杂度:O(N*logN)

  3. 空间复杂度:O(N)

  4. 稳定性:稳定

相关推荐
CSharp精选营4 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
刘马想放假8 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠8 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦15 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠16 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾16 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82116 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q16 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒17 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记17 天前
单项不带头不循环链表
数据结构·链表