Leetcode刷题(第56题)——合并区间

x33g5p2x  于2022-03-02 转载在 其他  
字(1.1k)|赞(0)|评价(0)|浏览(233)

一、题目

以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。

二、示例

示例一:
输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
输出:[[1,6],[8,10],[15,18]]
解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].

示例二
输入:intervals = [[1,4],[4,5]]
输出:[[1,5]]
解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。

三、思路
首先考虑特殊情况,如果输入数组的长度为1,则此时就直接输出该数组即可。如果不为1,然后先进行排序,此时按照每一个元素的0号位元素的大小进行排序即可,再取出每一个元素进行遍历
这里我们以[[2,6],[1,3],[8,10],[15,18]]为例

//1、首先先进行排序,排序完后的数组为
[[1,3],[2,6],[8,10],[15,18]]

//2、然后再新建一个数组,将第一个元素放入其中[[1,3]]
当遍历到第二个元素[2,6]时:由于2小于3,此时应该取6和3两者的最大值,此时数组为[[1, 6]]
当遍历到第三个元素[8,10]时,由于8大于6,此时应该直接将其插入数组中,此时数组为[[1,6],[8,10]
当遍历到第四个元素[15, 18]时,由于15大于10,此时应该直接将其插入数组中,此时数组为[[1,6],[8,10],[15, 18]]

四、代码

/**
 * @param {number[][]} intervals
 * @return {number[][]}
 */
var merge = function (intervals) {
    let length = intervals.length
    if (length === 1) return intervals
    intervals.sort((a, b) => a[0] - b[0])
    let result = [intervals[0]]
    for (let i = 1; i < length; i++) {
        let currentArr = intervals[i]
        let ret = result[result.length - 1][1]
        if(currentArr[0] > ret) {
            result.push(currentArr)
        }else {
            result[result.length - 1][1] = Math.max(ret, currentArr[1])
        }
    }
    return result
};

五、总结

相关文章