56.合并区间

56.合并区间



class Solution {
    public int[][] merge(int[][] intervals) {
        /**
            1.根据元素左侧的大小排序。
            2.判断合并
              a.如果下一个元素的左侧元素大于当前元素的右侧元素,不合并,直接加入。
              b.如果不是,进行合并,将当前元素的右侧元素和下一元素的右侧元素比较大小,去较大值为右侧元素。左侧元素不变。
         */

         if(intervals.length==0){
             return new int[0][2];
         }

        Arrays.sort(intervals,new Comparator<int[]>() {
            public int compare(int[] interval1,int[] interval2){
                return interval1[0]-interval2[0];
            }
        });
        

        // 存储最终结果
        List<int[]> merged = new ArrayList<int[]>();

        for(int i =0; i < intervals.length;i++){
            int L = intervals[i][0],R = intervals[i][1];
            if(merged.size()==0||merged.get(merged.size() - 1)[1] < L){
                merged.add(new int[]{L,R});
            }else{
                merged.get(merged.size()-1)[1] = Math.max(merged.get(merged.size()-1)[1],R);
            }
        }

        return merged.toArray(new int[merged.size()][]);
    }
}

作者:静默虚空
欢迎任何形式的转载,但请务必注明出处。
限于本人水平,如果文章和代码有表述不当之处,还请不吝赐教。

posted @   Chenyi_li  阅读(8)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示