Leetcode #57 插入区间

一、题目

在这里插入图片描述

二、思路

遍历所有区间,先找和插入区间不重叠的左边区间,条件是当前区间右边的值小于插入区间左边的值,再找和插入区间重叠的中间区间,条件是当前区间的左边的值小于等于插入区间右边的值,新插入区间左边的值是当前区间和插入区间左边较小的值,新插入区间右边的值是当前区间和插入区间右边较大的值,剩下的区间就是和插入区间不重叠的右边区间

三、代码实现

public int[][] insert(int[][] intervals, int[] newInterval) {
        List<int[]> res = new ArrayList<>();
        int i = 0, length = intervals.length;
        //不重叠的左边区间,当前区间的右边比插入区间的左边小
        while (i < length && intervals[i][1] < newInterval[0]) {
            res.add(intervals[i]);
            i++;
        }
        //重叠部分的中间区间,当前区间的左边小于等于插入区间的右边
        while (i < length && intervals[i][0] <= newInterval[1]) {
            //左边取当前区间左边和插入区间左边的较小值
            newInterval[0] = Math.min(newInterval[0],intervals[i][0]);
            //右边取当前区间右边和插入区间右边的较大值
            newInterval[1] = Math.max(newInterval[1],intervals[i][1]);
            i++;
        }
        res.add(newInterval);
        //不重叠的右边区间
        while (i < length) {
            res.add(intervals[i]);
            i++;
        }
        return res.toArray(new int[0][]);
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值