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

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

一、题目

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

二、示例

  1. 示例一:
  2. 输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
  3. 输出:[[1,6],[8,10],[15,18]]
  4. 解释:区间 [1,3] [2,6] 重叠, 将它们合并为 [1,6].
  5. 示例二
  6. 输入:intervals = [[1,4],[4,5]]
  7. 输出:[[1,5]]
  8. 解释:区间 [1,4] [4,5] 可被视为重叠区间。

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

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

四、代码

  1. /**
  2. * @param {number[][]} intervals
  3. * @return {number[][]}
  4. */
  5. var merge = function (intervals) {
  6. let length = intervals.length
  7. if (length === 1) return intervals
  8. intervals.sort((a, b) => a[0] - b[0])
  9. let result = [intervals[0]]
  10. for (let i = 1; i < length; i++) {
  11. let currentArr = intervals[i]
  12. let ret = result[result.length - 1][1]
  13. if(currentArr[0] > ret) {
  14. result.push(currentArr)
  15. }else {
  16. result[result.length - 1][1] = Math.max(ret, currentArr[1])
  17. }
  18. }
  19. return result
  20. };

五、总结

相关文章