后端开发刷题 | 合并区间

描述

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

请保证合并后的区间按区间起点升序排列。

数据范围:区间组数 0≤n≤2×105,区间内 的值都满足 0≤val≤2×105

示例1

输入:

复制代码
[[10,30],[20,60],[80,100],[150,180]]

返回值:

复制代码
[[10,60],[80,100],[150,180]]

示例2

输入:

复制代码
[[0,10],[10,20]]

返回值:

复制代码
[[0,20]]

思路分析:

该题可以使用贪心算法解决,找出整体当中给的每个局部子结构的最优解,并且最终将所有的这些局部最优解结合起来形成整体上的一个最优解。

步骤:

1.先把这些区间进行排序,使用 Collections.sort()方法

2.根据前一个区间的end小于当前区间的start,区间不重叠;反之则重叠。

3.将这些区间添加到res里面,最终返回res

代码分析:

java 复制代码
import java.util.*;

/*
 * public class Interval {
 *   int start;
 *   int end;
 *   public Interval(int start, int end) {
 *     this.start = start;
 *     this.end = end;
 *   }
 * }
 */

public class Solution {
    /**
     * 
     * @param intervals Interval类ArrayList 
     * @return Interval类ArrayList
     */
    public ArrayList<Interval> merge (ArrayList<Interval> intervals) {
        ArrayList<Interval> res=new ArrayList<>();
        //特殊情况
        if(intervals.size()==0) return res;
        //按区间进行排序
        Collections.sort(intervals,(o1,o2)->o1.start-o2.start);
        //把排序后的第一个区间放入res
        res.add(intervals.get(0));
        int before=0;
        for(int i=1;i<intervals.size();i++){
            Interval o1=intervals.get(i);
            Interval origin=res.get(before);

            //区间不重叠,前一个区间的end小于当前区间的start
            if(origin.end<o1.start){
                //添加
                res.add(o1);
                before++;
            }else{
                //区间重叠,前一个区间的end大于当前区间的start
                res.remove(before);
                Interval s=new Interval(origin.start,Math.max(origin.end,o1.end));
                res.add(s);
            }
        }
        return res;

    }
}
相关推荐
程序员的世界你不懂20 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
星空寻流年20 小时前
设计模式第一章(建造者模式)
java·设计模式·建造者模式
lingchen190620 小时前
MATLAB的数值计算(三)曲线拟合与插值
开发语言·matlab
gb421528721 小时前
java中将租户ID包装为JSQLParser的StringValue表达式对象,JSQLParser指的是?
java·开发语言·python
一朵梨花压海棠go21 小时前
html+js实现表格本地筛选
开发语言·javascript·html·ecmascript
曾经的三心草21 小时前
Python2-工具安装使用-anaconda-jupyter-PyCharm-Matplotlib
android·java·服务器
蒋星熠21 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
Metaphor69221 小时前
Java 高效处理 Word 文档:查找并替换文本的全面指南
java·经验分享·word
ChinaRainbowSea21 小时前
7. LangChain4j + 记忆缓存详细说明
java·数据库·redis·后端·缓存·langchain·ai编程
舒一笑21 小时前
同步框架与底层消费机制解决方案梳理
后端·程序员