给你两个按 非递减顺序 排列的整数数组 nums1 **和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。
请你 合并 nums2 **到 nums1 中,使合并后的数组同样按 非递减顺序 排列
注意: 最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n
示例 :
输入: nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3
输出: [1,2,2,3,5,6]
解释: 需要合并 [1,2,3] 和 [2,5,6] 。
合并结果是 [1,2,2,3,5,6] ,其中斜体加粗标注的为 nums1 中的元素。
题解 :
/**
* @param {number[]} nums1
* @param {number} m
* @param {number[]} nums2
* @param {number} n
* @return {void} Do not return anything, modify nums1 in-place instead.
*/
var merge = function (nums1, m, nums2, n) {
// 方法一:先合并在排序
// 合并后排序 截取num1多余替换为nums2
// 对nums1排序
nums1.splice(3, nums1.length - 1, ...nums2)
nums1.sort((a, b) => a - b)
// 方法二:双指针
let p1 = 0, p2 = 0, curr = [], index = 0
while (p1 < m || p2 < n) {
if (p1 == m) { // nums1到达边界时,遍历nums2
curr[index++] = nums2[p2++]
} else if (p2 == n) { // nums2到达边界,遍历nums1
curr[index++] = nums1[p1++]
} else if (nums1[p1] < nums2[p2]) { // nums1小于nums2时
curr[index++] = nums1[p1++]
} else {// nums1大于nums2时
curr[index++] = nums2[p2++]
}
}
// 赋值给nums1
for (let i = 0; i < curr.length; i++) {
nums1[i] = curr[i]
}
};