Leetcode 56 合并区间
2023-12-27 23:41:26
题意理解:???????
????????以数组?intervals?表示若干个区间的集合,其中单个区间为?intervals[i] = [starti, endi]?。
????????合并所有重叠的区间,并返回?一个不重叠的区间数组。
????????该数组需恰好覆盖输入中的所有区间?。? ? ? ? 目标:合并所有重叠区间,则原有区间的右边界可能发生变化。
解题思路:
? ? ? ? 采用贪心探索每个独立区间的最右区间。
? ? ? ? 首先,要识别重叠的区间,用于后续处理。按照每个区间的左边界升序排序。
? ? ? ? 当且仅当,(i-1区间的右边界)>=(i区间的左边界),即为i区间和i-1区间重叠。
? ? ? ? 识别出重叠区间后,对最左区间的右边界进行探索,获得两区间合并后的最远右边界。
? ? ? ?以此完成区间合并——获得一个新区间。
????????
? ? ? ? 若区间无重叠现象,则直接作为一个独立区间加入结果集。
????????
1.贪心解题
明确全局最优解: 划分独立的区间。局部最优解:尽可能延长重叠区域的右区间。
为鉴别重叠区域,首先按照左边界升序排序。
对于重叠的区域总是更新合理的右边界。
将合并后的新区间及独立的老区间加入结果集。
注意:List转数组:
方法一:
int[][] resultArr=new int[result.size()][2];
for(int i=0;i<result.size();i++) resultArr[i]=result.get(i);
方法二:
res.toArray(new int[res.size()][]);
public int[][] merge(int[][] intervals) {
//按照左边界升序排序
Arrays.sort(intervals,(a,b)->Integer.compare(a[0],b[0]));
//记录结果集
LinkedList<int[]> result = new LinkedList<>();
result.add(intervals[0]);
for(int i=1;i<intervals.length;i++){
//有重叠,更新右边界
if(intervals[i-1][1]>=intervals[i][0]){
intervals[i][1]=Math.max(intervals[i-1][1],intervals[i][1]);
result.getLast()[1]=intervals[i][1];
}else{
//无重叠,加入新区间
result.add(intervals[i]);
}
}
return result.toArray(new int[result.size()][]);
}
2.分析?
时间复杂度:O(n logn) 主要的时间耗费是排序和遍历数组。
空间复杂度:O(logn) 主要的空间耗费是排序所需的额外空间。
文章来源:https://blog.csdn.net/lt_BeiMo/article/details/135251047
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!