【分治】归并排序——排序数组(medium)

排序数组(medium)

题⽬链接:912. 排序数组

题⽬描述:

给你⼀个整数数组 nums,请你将该数组升序排列。

⽰例 1:

输⼊:nums = [5,2,3,1]

输出:[1,2,3,5]

⽰例 2:

输⼊:nums = [5,1,1,2,0,0]

输出:[0,0,1,1,2,5]

解法(归并排序):

算法思路:

归并排序的流程充分的体现了「分⽽治之」的思想,⼤体过程分为两步:

◦ 分:将数组⼀分为⼆为两部分,⼀直分解到数组的⻓度为 1 ,使整个数组的排序过程被分为「左半部分排序」 + 「右半部分排序」;

◦ 治:将两个较短的「有序数组合并成⼀个⻓的有序数组」,⼀直合并到最初的⻓度。

算法代码:

java 复制代码
class Solution{
 int[] tmp;
 public int[] sortArray(int[] nums) {
	 tmp = new int[nums.length];
	 mergeSort(nums, 0, nums.length - 1);
	 return nums;
 }
 public void mergeSort(int[] nums, int left, int right){
	 if(left >= right) return;
	 
	 // 1. 根据中间点划分区间
	 int mid = (left + right) / 2;
	 // [left, mid] [mid + 1, right]
	 
	 // 2. 先把左右区间排个序
	 mergeSort(nums, left, mid);
	 mergeSort(nums, mid + 1, right);
	 
	 // 3. 合并两个有序数组
	 int cur1 = left, cur2 = mid + 1, i = 0;
	 while(cur1 <= mid && cur2 <= right)
	 	tmp[i++] = nums[cur1] <= nums[cur2] ? nums[cur1++] : nums[cur2++];
	 // 处理没有遍历完的数组
	 while(cur1 <= mid) tmp[i++] = nums[cur1++];
	 while(cur2 <= right) tmp[i++] = nums[cur2++];
	 // 4. 还原
	 for(int j = left; j <= right; j++) 
	 	nums[j] = tmp[j - left];
 }
}
相关推荐
艾醒5 分钟前
大模型原理剖析——多头潜在注意力 (MLA) 详解
算法
艾醒9 分钟前
大模型原理剖析——DeepSeek-V3深度解析:671B参数MoE大模型的技术突破与实践
算法
jifengzhiling1 小时前
零极点对消:原理、作用与风险
人工智能·算法
鲨莎分不晴2 小时前
【前沿技术】Offline RL 全解:当强化学习失去“试错”的权利
人工智能·算法·机器学习
qq_12498707532 小时前
重庆三峡学院图书资料管理系统设计与实现(源码+论文+部署+安装)
java·spring boot·后端·mysql·spring·毕业设计
大学生资源网2 小时前
java毕业设计之“知语”花卉销售网站的设计与实现源码(源代码+文档)
java·mysql·毕业设计·源码·springboot
小鸡脚来咯2 小时前
Redis三大问题:穿透、击穿、雪崩(实战解析)
java·spring·mybatis
桦说编程2 小时前
并发编程高级技巧:运行时检测死锁,告别死锁焦虑
java·后端·性能优化
jiayong232 小时前
Spring AI Alibaba 深度解析(三):实战示例与最佳实践
java·人工智能·spring