码迷,mamicode.com
首页 > 其他好文 > 详细

leetcode

时间:2020-06-17 18:13:25      阅读:48      评论:0      收藏:0      [点我收藏+]

标签:color   数组   max   ==   string   ring   else   strong   array   

1、合并区间

  给出一个区间的集合,请合并所有重叠的区间。

示例 1:

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

示例 2:

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

import java.util.Arrays;

public class merge_56 {

    public static void main(String[] args) {
        int[][] intervals = {{1,4},{0,4}};
        int[][] result = merge(intervals);
    }
    public static int[][] merge(int[][] intervals) {
        if(intervals.length == 0)return intervals;
         // 先按照区间起始位置排序
        Arrays.sort(intervals, (v1, v2) -> v1[0] - v2[0]);
        // 遍历区间
        int[][] res = new int[intervals.length][2];
        int idx = -1;
        for (int[] interval: intervals) {
            // 如果结果数组是空的,或者当前区间的起始位置 > 结果数组中最后区间的终止位置,
            // 则不合并,直接将当前区间加入结果数组。
            if (idx == -1 || interval[0] > res[idx][1]) {
                res[++idx] = interval;
            } else {
                // 反之将当前区间合并至结果数组的最后区间
                res[idx][1] = Math.max(res[idx][1], interval[1]);
            }
        }
        return Arrays.copyOf(res, idx + 1);
    }


    }

 

leetcode

标签:color   数组   max   ==   string   ring   else   strong   array   

原文地址:https://www.cnblogs.com/lgh544/p/13153911.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!