2020/10/6 Acwing-区间合并

题目

给定 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

题目分析

对于给出的任意区间进行合并,首先要做的就是对输入的区间进行排序,排序的方式是按照左端点.然后依次判断下一个区间的左端点和之前右端点的关系,来判断到底区间是合并还是重新开辟.

算法解析

  1. 对左端点进行排序
  2. 输入新的区间,对现有区间进行管理

源代码

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要全部设为极限左端点,这样任意给一个区间都可以进行区间操作.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值