题目
给定 n 个区间 [li,ri],要求合并所有有交集的区间。
注意如果在端点处相交,也算有交集。
输出合并完成后的区间个数。
例如:[1,3]和[2,6]可以合并为一个区间[1,6]。
输入格式
第一行包含整数n。
接下来n行,每行包含两个整数 l 和 r。
输出格式
共一行,包含一个整数,表示合并区间完成后的区间个数。
数据范围
1≤n≤100000,
−109≤li≤ri≤109
输入样例:
5
1 2
2 4
5 6
7 8
7 9
输出样例:
3
题目分析
对于给出的任意区间进行合并,首先要做的就是对输入的区间进行排序,排序的方式是按照左端点.然后依次判断下一个区间的左端点和之前右端点的关系,来判断到底区间是合并还是重新开辟.
算法解析
- 对左端点进行排序
- 输入新的区间,对现有区间进行管理
源代码
import java.util.*;
class Main{
public static void main(String[] args){
Scanner sc=new Scanner(System.in);
int n=sc.nextInt();
List<Pairs> list=new ArrayList<>();
while(n-->0){
int l=sc.nextInt();
int r=sc.nextInt();
list.add(new Pairs(l,r));
}
Collections.sort(list);
int count=0;
int l=(int)-(1e9);
int r=(int)-(1e9);
for(Pairs item:list){
if(item.first>r){
count++;
l=item.first;
r=item.second;
}
else{
r=Math.max(item.second,r);
}
}
System.out.print(count);
};
}
class Pairs implements Comparable<Pairs>{
int first;
int second;
Pairs(int first,int second){
this.first=first;
this.second=second;
}
@Override
public int compareTo(Pairs p) {
return this.first-p.first;
}
}
解法细节
这里我新建了一个Pairs类来存储每一组区间,并将这些对对象存入了ArrayList数组中,在Pairs类中实现了compareable接口,利用左端点进行比较,从而调用集合工具类就可以实现按左端点排序.
当然,在存储时并不一定需要新建类,同样可以建二维数组在存储左右端点,由于数组同样可以看做对象,因此同样可以新建一个比较器来对List进行排序.
需要注意的是,起始的l,r
要全部设为极限左端点,这样任意给一个区间都可以进行区间操作.