Java合并区间的实现
问题:
以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。
示例:
示例 1:
输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
输出:[[1,6],[8,10],[15,18]]
解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].
示例 2:
输入:intervals = [[1,4],[4,5]]
输出:[[1,5]]
解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。
提示:
- 1 <= intervals.length <= 104
- intervals[i].length == 2
- 0 <= starti <= endi <= 104
思路: 首先对所有区间进行排序,使其变成有序区间,然后分别取每个区间的元素,如果当前end值不大于下一个区间的start就将其加入数组中,否则就进行比较,最大的值作为end值,具体步骤如代码所示。
代码:
class Solution { public int[][] merge(int[][] intervals) { int n = intervals.length; //先对数组进行排序 Arrays.sort(intervals,(a,b)->a[0] - b[0]); List<int[]> list = new ArrayList<>(); int starti = -1; int endi = -1; for(int[] inertval : intervals){ if(endi < inertval[0]){ if(starti != -1){ list.add(new int[]{starti,endi}); } starti = inertval[0]; endi = inertval[1]; } else { endi = Math.max(endi,inertval[1]); } } list.add(new int[]{starti,endi}); int[][] ans = new int[list.size()][2]; for(int i = 0; i < ans.length; i++){ans[i] = list.get(i);} return ans; } }
到此这篇关于Java合并区间的实现的文章就介绍到这了,更多相关Java合并区间内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
kafka并发写大消息异常TimeoutException排查记录
这篇文章主要为大家介绍了kafka并发写大消息异常TimeoutException的排查记录及解决方案,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步2022-02-02IntelliJ IDEA 2020.3 重大特性(新功能一览)
这篇文章主要介绍了IntelliJ IDEA 2020.3 重大特性(新功能一览),本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-12-12Java中FilterInputStream和FilterOutputStream的用法详解
这篇文章主要介绍了Java中FilterInputStream和FilterOutputStream的用法详解,这两个类分别用于封装输入和输出流,需要的朋友可以参考下2016-06-06Spring Boot前后端分离开发模式中的跨域问题及解决方法
本文介绍了解决Spring Boot前端Vue跨域问题的实战经验,并提供了后端和前端的配置示例,通过配置后端和前端,我们可以轻松解决跨域问题,实现正常的前后端交互,需要的朋友可以参考下2023-09-09Spring Boot MQTT Too many publishes in progress错误的解决方
本文介绍Spring Boot MQTT Too many publishes in progress错误的解决方案,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感兴趣的小伙伴可以参考一下2022-07-07
最新评论