算法(TS):合并二维有序数组成一维有序数组

合并二维有序数组成一维有序数组的核心是合并有序的一维数组,声明变量 answer 为最终的合并结果,其初始值为 arr[0]。

第一步将 arr[1] 合并到 answer, 第二步将 arr[2] 合并到 answer,回到 arr 中的所有一维数组合并到 answer。

ts 复制代码
function mergeArr(arr: number[][]):number[] {
    if(arr.length === 0) return[]
    const answer: number[] = [...arr[0]]
    const len = arr.length
    let index = 1
    // 合并两个有序一维数组
    const merge = (origin: number[],target:number[]) => {
        let i = origin.length - 1,j = target.length - 1
        target.push(...new Array(origin.length))
        let targetIndex = target.length - 1,cur
        while(i >= 0 || j >= 0) {
            let cur: number = origin[i]
            if(i < 0) {
                cur = target[j]
                j--
            } else if(j < 0) {
                cur = origin[i]
                i--
            } else if(origin[i] >= target[j]) {
                cur = origin[i]
                i--
            } else if(origin[i] < target[j]) {
                cur = target[j]
                j--
            }

            target[targetIndex] = cur
            targetIndex--
        }
    }

    while(index < len) {
        merge(arr[index],answer)
        index++
    }

    return answer
}
相关推荐
西陵12 分钟前
Nx带来极致的前端开发体验——任务缓存
前端·javascript·架构
晚风残28 分钟前
【C++ Primer】第六章:函数
开发语言·c++·算法·c++ primer
Panda__Panda29 分钟前
docker项目打包演示项目(数字排序服务)
运维·javascript·python·docker·容器·c#
杨云强38 分钟前
离散积分,相同表达式数组和公式
算法
地平线开发者39 分钟前
征程 6 | BPU trace 简介与实操
算法·自动驾驶
满天星830357742 分钟前
【C++】AVL树的模拟实现
开发语言·c++·算法·stl
Lris-KK1 小时前
力扣Hot100--94.二叉树的中序遍历、144.二叉树的前序遍历、145.二叉树的后序遍历
python·算法·leetcode
10年前端老司机2 小时前
Promise 常见面试题(持续更新中)
前端·javascript
麦麦鸡腿堡2 小时前
Java的动态绑定机制(重要)
java·开发语言·算法
zy_destiny2 小时前
【工业场景】用YOLOv8实现抽烟识别
人工智能·python·算法·yolo·机器学习·计算机视觉·目标跟踪