排序算法之归并排序

归并排序的核心思想是将需要排序的数据(通常是数组),切分成不同的小段,对每一段数据先在内部排序,然后将各个段再进行合并排序,比如给定一个数组[2,1,4,3],可以先将数组切分成两个小数组也就是[2,1]和[4,3],然后分别对两个小数组进行内部排序,也就是排成[1,2]和[3,4],然后再对这两个小数组进行合并排序,在对这两个小数组合并排序的时候,我们按照这个步骤来操作:

  1. 新建一个数组,长度是总数组的长度,也就是4,我们记这个数组为help

  2. 分别有两个指针P1和P2指向两个小数组的第一个元素,然后移动两个指针,哪个数组对应的指针所指的数据小,就将它拷贝到help当中,如果有一个指针先移动结束,那么另一个数组当前指针所指的位置以及后面的数据直接拷贝到help即可

  3. 将help数组的数据还原到原数组中

代码实现:

复制代码
private void mergeSort(int[] arr, int start, int end) {
        if (start == end) {
            return;
        }
        int middle = start + ((end - start) >> 1);
        mergeSort(arr, start, middle);
        mergeSort(arr, middle + 1, end);
        merge(arr, start, middle, end);
    }

    private void merge(int[] arr, int start, int middle, int end) {
        System.err.println(start + ":" + middle + ":" + end);
        int i = 0;
        int[] help = new int[end - start + 1];
        int index1 = start;
        int index2 = middle + 1;
        while (index1 <= middle && index2 <= end) {
            help[i++] = arr[index1] <= arr[index2] ? arr[index1++] : arr[index2++];
        }
        while (index1 <= middle) {
            help[i++] = arr[index1++];
        }
        while (index2 <= end) {
            help[i++] = arr[index2++];
        }
        int length = help.length;
        for (int i1 = 0; i1 < length; i1++) {
            arr[start + i1] = help[i1];
        }
    }

    @Test
    public void mergeSort() {
        int[] array = new int[]{3, 2, 5, 4};
        int length = array.length;
        mergeSort(array, 0, length - 1);
    }
相关推荐
Gerardisite几秒前
企业微信智能客服开发实战:API自动回复指南
java·开发语言·python·机器人·企业微信
NNYSJYKJ2 分钟前
K12 学习常见问题破解:脑能思维链的算法与教育应用
学习·算法
要开心吖ZSH3 分钟前
零基础入门 Spring WebFlux 与 Project Reactor:从小白到顿悟
java·响应式编程·spring webflux
智塑未来3 分钟前
装备制造行业设计制造一体化痛点攻克与实战经验总结
java·开发语言·制造
Devin~Y8 分钟前
电商AIGC智能客服面试:JVM调优、Spring Cloud微服务、Redis缓存、Kafka消息、K8s观测与RAG落地
java·jvm·spring boot·redis·spring cloud·kafka·kubernetes
Ai马猴子11 分钟前
企业定制专属模型,gpt-5.4-cdx高效适配,DMXAPI 安全合规
java·gpt·安全
2301_7890156211 分钟前
Linux:基础指令(二)
linux·运维·服务器·c语言·开发语言·c++·算法
星晨羽15 分钟前
Java通过FTP协议实现文件上传下载
java·开发语言
逸Y 仙X15 分钟前
文章三十:Elasticsearch SQL实战案例
java·大数据·sql·elasticsearch·搜索引擎·全文检索
闻缺陷则喜何志丹16 分钟前
【区间合并】P7912 [CSP-J 2021] 小熊的果篮|普及+
c++·算法·洛谷·区间合并