【LeetCode-面试算法经典-Java实现】【056-Merge Intervals(区间合并)】
2024-09-21 09:04:19
【056-Merge Intervals(区间合并)】
【LeetCode-面试算法经典-Java实现】【全部题目文件夹索引】
原题
Given a collection of intervals, merge all overlapping intervals.
For example,
Given [1,3],[2,6],[8,10],[15,18]
,
return [1,6],[8,10],[15,18]
.
题目大意
给定一个区间集合,合并有重叠的区间。
解题思路
先对区间进行排序。按開始点进行排序,再一个一个进行合并。
代码实现
算法实现类
import java.util.*;
public class Solution {
public List<Interval> merge(List<Interval> intervals) {
List<Interval> result = new LinkedList<>();
if (intervals == null || intervals.size() < 1) {
return result;
}
// 先对区间进行排序,使用一个匿名内部类
Collections.sort(intervals, new Comparator<Interval>() {
@Override
public int compare(Interval o1, Interval o2) {
return o1.start - o2.start;
}
});
// 排序后,后一个元素(记为next)的start一定是不小于前一个(记为prev)start的,
// 对于新加入的区间,假设next.start大于prev.end就说明这两个区间是分开的,要添
// 加一个新的区间。否则说明next.start在[prev.start, prev.end]内。则仅仅要看
// next.end是否是大于prev.end,假设大于就要合并区间(扩大)
Interval prev = null;
for (Interval item : intervals) {
if (prev == null || prev.end < item.start) {
result.add(item);
prev = item;
} else if (prev.end < item.end) {
prev.end = item.end;
}
}
return result;
}
}
评測结果
点击图片。鼠标不释放,拖动一段位置,释放后在新的窗体中查看完整图片。
特别说明
欢迎转载,转载请注明出处【http://blog.csdn.net/derrantcm/article/details/47120501】
最新文章
- jQuery实践树(2)
- 15个最佳的代码评审(Code Review)工具
- UNIX 系统上的文本操作简介
- web容器线程数和程序中线程阻塞导致 请求超时
- 安装Ubuntu小计
- iOS多线程中的单例
- [ASP.NET]利用itextsharp将GridView汇出PDF档
- 统计solr multivalued 字段中数目
- Nodejs package.json文件介绍
- SQL Server 2005的服务器角色(public)的问题
- 简单剖析Node中的事件监听机制(一)
- Spring Boot + Spring Cloud 实现权限管理系统 配置中心(Config、Bus)
- C++:STL vector:sizeof(vector)
- MySQL中的文件
- 统计python文件中的代码,注释,空白对应的行数
- 实现域名访问网站—nginx反向代理
- pyqt5开发环境安装
- java学习-GET方式抓取网页(UrlConnection和HttpClient)
- 安装ffmpeg
- 单例设计模式-java