算法通关村第十关|黄金挑战|归并排序

归并排序:先将大的序列分为若干个小的序列,得到答案后再将答案合并,递归深度为 log n 。

实现:

java 复制代码
public void mergeSort(int[] array, int start, int end, int temp[]) {
	if (start >= end) {
        return;
    }
    mergeSort(array, start, (start + end) / 2, temp);
    mergeSort(array, (start + end) / 2 + 1, end, temp);
    merge(array, start, end, temp);
}
public void merge(int[] array, int start, int end, int[] temp) {
	int middle = (start + end) / 2;
    int left = start;
    int right = middle + 1;
    int index = left;
    while (left <= middle && right <= end) {
        if (array[left] < array[right]) {
            temp[index++] = array[left++];
        } else {
            temp[index++] = array[right++];
        }
    }
    while (left <= middle) {
        temp[index++] = array[left++];
    }
    while (right <= end) {
        temp[index++] = array[right++];
    }
    for (int i = start; i <= end; i++) {
        array[i] = temp[i];
    }
}

如果对您有帮助,请点赞关注支持我,谢谢!❤

如有错误或者不足之处,敬请指正!❤

个人主页:星不易

算法通关村专栏:不易|算法通关村

相关推荐
程序员二叉几秒前
【Java】String 全套高频面试题详解
java·开发语言·面试
仍然.1 分钟前
算法题目---BFS解决FloodFill算法问题
算法·宽度优先
字节高级特工6 分钟前
C++11(三)终极指南:可变参数模板与包装器详解
java·开发语言·c++·后端
Sirius Wu11 分钟前
MoE与Fengyu-Dense_架构对比及训练方案
人工智能·深度学习·算法·机器学习·语言模型·架构
却道天凉_好个秋12 分钟前
HEVC(一):环路滤波
人工智能·算法·计算机视觉·环路滤波
8Qi820 分钟前
LeetCode 300 & 674:最长递增子序列 vs 最长连续递增子序列
算法·leetcode·职场和发展·动态规划
用户2986985301424 分钟前
Java 实现 Word 文档内容复制:段落、章节与全文合并技巧
java·后端
sheeta199828 分钟前
LeetCode 补拙笔记 日期:2026.06.07 题目:283. 移动零
笔记·算法·leetcode
摇滚侠28 分钟前
Maven 入门+高深 SSM 案例 111-112
java·数据库·maven
Chase_______32 分钟前
【Java基础 | 16】集合框架(下):Map、HashMap 与 TreeMap
java·windows