合并区间题解

题目链接

56. 合并区间 - 力扣(LeetCode)

思路

  1. 解题第一步,先排序,排序是最先必须需要做的事情

  2. 根据排序,我们结果数组 res ,pos 作为当前res结果数组已经存储了几个,对于 intervals 数组第一个元素,我们直接 push 进入 res ,从 第二个元素开始进行遍历,我们看当前元素是否 小于,当前res数组位置的 right,如果满足条件,则更新 res 数组对应下标 pos 的 right,否则就直接把 intervals 当前元素 push 到res作为新的区间

代码

javascript 复制代码
/**
 * @param {number[][]} intervals
 * @return {number[][]}
 */
var merge = function (intervals) {

    if (intervals.length < 1) return []
    if (intervals.length < 2) return intervals
    // 先排序
    intervals = intervals.sort((a, b) => {
        if (a[0] != b[0]) return a[0] - b[0]
        else return a[1] - b[1]
    })

    console.log(intervals)

    let res = [intervals[0]], pos = 0

    for (let i = 1; i < intervals.length; i++) {
        if (intervals[i][0] <= res[pos][1]) {
            // 可以合并
            res[pos][1] = Math.max(intervals[i][1], res[pos][1])
        }
        else {
            res.push(intervals[i])
            pos++
        }
    }

    return res
};
相关推荐
淡忘旧梦3 分钟前
词错误率/WER算法讲解
人工智能·笔记·python·深度学习·算法
狐5714 分钟前
2026-01-21-牛客每日一题-静态区间和(前缀和)
笔记·算法
2401_8414956416 分钟前
【Python高级编程】单词统计与查找分析工具
数据结构·python·算法·gui·排序·单词统计·查找
源代码•宸35 分钟前
Leetcode—3. 无重复字符的最长子串【中等】
经验分享·后端·算法·leetcode·面试·golang·string
范纹杉想快点毕业39 分钟前
嵌入式工程师一年制深度进阶学习计划(纯技术深耕版)
linux·运维·服务器·c语言·数据库·算法
-To be number.wan43 分钟前
【数据结构真题解析】哈希表高级挑战:懒惰删除、探测链断裂与查找正确性陷阱
数据结构·算法·哈希算法
历程里程碑1 小时前
哈希2:字母异位符分组
算法·leetcode·职场和发展
AI科技星1 小时前
统一场论理论下理解物体在不同运动状态的本质
人工智能·线性代数·算法·机器学习·概率论
txinyu的博客1 小时前
sprintf & snprintf
linux·运维·算法
pas1361 小时前
34-mini-vue 更新element的children-双端对比diff算法
javascript·vue.js·算法