【面试经典150题】合并两个有序数组-JS版

题目来源

初始思路:同时循环遍历两个数组,选出较小元素放入新数组。剩下一个没有被遍历完的数组的剩余元素直接拼接到新数组后。

错误示例

javascript 复制代码
var merge = function (nums1, m, nums2, n) {
    let i = 0,
        j = 0,
        nums3 = [];
    while (i < m && j < n) {
        if (nums1[i] <= nums2[j]) {
            nums3.push(nums1[i++]);
        } else {
            nums3.push(nums2[j++]);
        }
    }
    if (i < m) {
        nums3 = nums3.concat(nums1.slice(i, m));
    }
    if (j < n) {
        nums3 = nums3.concat(nums2.slice(j, n));
    }
    nums1 = nums3;
};

nums1 = nums3 不会改变原数组,这样做只是改变了参数nums1 指向了nums3的内容,但是原nums1内容并没有改变。


正确示例1

javascript 复制代码
var merge = function (nums1, m, nums2, n) {
    let i = 0,
        j = 0,
        nums3 = [];
    while (i < m && j < n) {
        if (nums1[i] <= nums2[j]) {
            nums3.push(nums1[i++]);
        } else {
            nums3.push(nums2[j++]);
        }
    }
    if (i < m) {
        nums3 = nums3.concat(nums1.slice(i, m));
    }
    if (j < n) {
        nums3 = nums3.concat(nums2.slice(j, n));
    }
    for (let i = 0; i < nums1.length; i++) {
        nums1[i] = nums3[i];
    }
    //nums1.splice(0, nums1.length, ...nums3);
};

直接改变nums1对应的区域的值。

++注意使用splice方法会有一定的空间损耗++。

时间复杂度 : O ( m + n ) O(m+n) O(m+n)。

空间复杂度 : O ( m + n ) O(m+n) O(m+n)。

正确示例1可以优化的地方:辅助数组nums3可以不用,我们从后往前遍历,依次选择较大的填入nums1。


正确示例2省去nums3数组

javascript 复制代码
var merge = function(nums1, m, nums2, n){
    let i = m - 1, j = n - 1, k = m + n - 1;
    while(i>=0&&j>=0){
        if(nums1[i]>nums2[j]){
            nums1[k--]=nums1[i--];
        }else{
            nums1[k--]=nums2[j--];
        }
    }
    while(j>=0){
        nums1[k--]=nums2[j--];
    }
    // nums1.splice(0,j+1,...nums2.slice(0,j+1));
}

时间复杂度 : O ( m + n ) O(m+n) O(m+n)

空间复杂度 : O ( 1 ) O(1) O(1)

小伙伴们有更好的解法吗?

相关推荐
嵌入式学习之旅1 小时前
嵌入式面试1103
面试·职场和发展
蒙奇D索大1 小时前
【算法】递归算法实战:汉诺塔问题详解与代码实现
c语言·考研·算法·面试·改行学it
重铸码农荣光3 小时前
从「[1,2,3].map (parseInt)」踩坑,吃透 JS 数组 map 与包装类核心逻辑
面试·node.js
陌路203 小时前
S14排序算法--基数排序
算法·排序算法
Yue丶越3 小时前
【C语言】深入理解指针(二)
c语言·开发语言·数据结构·算法·排序算法
疯狂踩坑人3 小时前
结合400行mini-react代码,图文解说React原理
前端·react.js·面试
程序员爱钓鱼5 小时前
Python编程实战——Python实用工具与库:Numpy基础
后端·python·面试
晨非辰6 小时前
【数据结构初阶】--从排序算法原理分析到代码实现操作,参透插入排序的奥秘!
c语言·开发语言·数据结构·c++·算法·面试·排序算法
三川6987 小时前
排序算法介绍
数据结构·算法·排序算法
priority_key14 小时前
排序算法:堆排序、快速排序、归并排序
java·后端·算法·排序算法·归并排序·堆排序·快速排序