归并排序Java实现

本文详细解析了归并排序算法的实现过程,通过将数组左右均分,两侧独立排序,最后利用外部排序的方式进行整体排序,实现了从无序到有序的转变。代码示例清晰展示了递归排序和归并操作的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

思路:将一个数组左右均分,两侧排好序,再利用外排整体排序

//归并排序从小到大
public class MergeSort {
	public static void merge(int[] arr, int l, int m, int r) {
		int[] help = new int[r - l + 1];// 辅助数组,用于外排
		int p1 = l, p2 = m + 1;// 定义两个指针,分别对左右两边的数遍历
		int i = 0;
		while (p1 <= m && p2 <= r) {// 左右两边第一个数谁小把谁放到help,然后它的指针向后移动
			if (arr[p1] <= arr[p2]) {
				help[i] = arr[p1];
				i++;
				p1++;
			} else {
				help[i] = arr[p2];
				i++;
				p2++;
			}
		}
		while (p1 <= m) {// 右边已经为空
			help[i] = arr[p1];
			i++;
			p1++;
		}
		while (p2 <= r) {// 左边为空
			help[i] = arr[p2];
			i++;
			p2++;
		}
		for (int j = l; j < help.length; j++) {
			arr[j] = help[j];
		}
	}

	public static void mergeSort(int[] arr, int l, int r) {
		if (l == r) {// 递归中止条件
			return;
		}
		int mid = (l + r) / 2;
		mergeSort(arr, l, mid);// 对左边递归排序
		mergeSort(arr, mid + 1, r);// 右边递归排序
		merge(arr, l, mid, r);// 左右进行归并
	}

	public static void main(String[] args) {
		int arr[] = { 3, 1, 5, 7, 22, 11, 77, 34, 65 };
		mergeSort(arr, 0, arr.length - 1);
		for (int i : arr) {
			System.out.println(i);
		}
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值