【LeetCode】56-合并区间
2024-09-01 07:23:22
题目描述
给出一个区间的集合,请合并所有重叠的区间。
示例 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] 可被视为重叠区间。
解题思路
定义一个比较器,按照区间的起始值排序
使用上述比较器对区间集合进行排序
遍历区间集合,使用一个链表
merged
保存合并后的结果- 如果当前区间和结果链表的尾部没有交集,就直接加入结果链表
- 如果当前区间和结果链表的尾部有交集,就先跟结果链表尾部合并一下
- 合并方法:结果链表尾部的区间结束值取较大的那一个
Java 实现
private class IntervalComparator implements Comparator<Interval> {
@Override
public int compare (Interval a, Interval b) {
return Integer.compare(a.start, b.start);
}
}
public List<Interval> merge (List<Interval> intervals) {
intervals.sort(new IntervalComparator());
LinkedList<Interval> merged = new LinkedList<>();
for (Interval interval : intervals) {
if (merged.isEmpty() || interval.start > merged.getLast().end) {
// 如果没有重叠的部分,就直接加入
merged.add(interval);
} else {
// 如果有重叠的部分,就先合并一下
merged.getLast().end = Math.max(merged.getLast().end, interval.end);
}
}
return merged;
}
心得体会
这一题不是考察经典的排序算法,而是考察排序的应用。另外,定义比较器的代码也需要重视。
最新文章
- 函数Curry化
- Nexus3.0私服搭建
- SOA (面向服务的体系结构)
- scp 在Ubuntu下传文件 基于ssh
- 在PHPstorm编辑器中配置git环境
- Git教程之安装配置(1)
- Pyqt5.2.1生成的.ui文件转换成.py
- 将Winform程序快速转换为在浏览器中运行的程序
- oracle批量导出AWR报告
- 学习笔记_Java_day13_JSTL标签库(1、2、3、4、5、6、7、8)
- 1003 Crashing Balloon
- 无U盘安装Linux openSUSE(通过硬盘安装Linux)
- 第三方库FMDB的使用
- hdu 5600 BestCoder Round #67 (div.2)
- 获取imageView的图和背景图
- 关于OSError: [WinError 10038] 在一个非套接字上尝试了一个操作。
- Ubuntu 16.04 安装opencv3.4.5/cuda/caffe并使用jni笔记
- opensetting禁用后小程序二次授权的问题-以及根据定位城市获取天气
- Promise对象的含义和基本用法
- (转)Tiny210v2( S5PV210 ) 平台下 FIMD 对应 的 framebuffer 驱动中,关于 video buffer 的理解