一、题目
以数组 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
};
五、总结
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/weixin_47450807/article/details/123233678
内容来源于网络,如有侵权,请联系作者删除!