🎗️ 主页:小夜时雨
🎗️专栏:动态规划
🎗️如何活着,是我找寻的方向
题目链接: https://leetcode.cn/problems/merge-sorted-array/description/

本道题是归并排序的核心代码区间, 所以还是十分重要的, 接下来我们来分析一下这道题目.
具体实现过程:
看下面的代码对照着上面的流程解析会更加的清楚。
其实还有一种直接在原数组中进行拷贝的, 并不需要用到辅助数组,但是为了和后续归并排序联系在一起,我们此处只介绍了用辅助数组的具体过程,这个也更加容易理解(我们把不用辅助数组的代码也贴在最后面)。
// 这个就是归并排序的核心部分。 必须要会
// 归并排序中用的就是这个思想。
public void merge(int[] nums1, int m, int[] nums2, int n) {
int[] tmp = new int[m + n];
int cur1 = 0, cur2 = 0, i = 0;、
// 合并两个有序数组到辅助数组中
while(cur1 <= m - 1 && cur2 <= n - 1)
tmp[i++] = nums1[cur1] <= nums2[cur2] ? nums1[cur1++] : nums2[cur2++];
// 处理还没有遍历完的数组. 上面条件是并的关系,所以下面的while循环只会有一个执行
while(cur1 <= m - 1) tmp[i++] = nums1[cur1++];
while(cur2 <= n - 1) tmp[i++] = nums2[cur2++];
// 遍历原数组, 还原辅助数组到原数组中
for(int j = 0; j < m + n; j++) {
nums1[j] = tmp[j];
}
return;
}
不需要用到拷贝数组的写法代码(建议学会上面那一种写法,容易理解):
public void merge2(int[] nums1, int m, int[] nums2, int n) {
//有一点利用归并排序的思想
int i = m -1;
int j = n -1; //分别记录有效数据的最后一位
int k = m + n - 1; //记录nums1数组的最后一个位置
// && 逻辑与 是为了保证索引不越界
while(i >= 0 && j >= 0) {
if (nums1[i] <= nums2[j]) {
nums1[k] = nums2[j];
k--;
j--;
}else {
nums1[k] = nums1[i];
k--;
i--;
}
}
// 走到这说明i 和 j有一个不为0,其中不用管数组1中的数据,因为要拷贝到数组1中,本身就是有序的。
// 只需要判断 数组2的情况就行,把数组2中的数据拷贝到数组1中去
// 即是有可能数组1走完了,数组2中还有数据
while(j >= 0) {
nums1[k] = nums2[j];
k--;
j--;
}
}
🎗️🎗️🎗️ 好啦,到这里有关本题的分享就没了,如果感觉做的还不错的话可以点个赞,关注一下,你的支持就是我继续下去的动力,我们下期再见,拜了个拜~ ☆*: .。. o(≧▽≦)o .。.:*☆