区间连接器 华为OD真题 200

public class Main{
 
    public static void main(String[] args) {
 
        Scanner sc = new Scanner(System.in);
        String[] regionsStr = sc.nextLine().replaceAll("\\[","")
                                         .replaceAll("]","")
                                         .split(",");
        String[] linksStr = sc.nextLine().replaceAll("\\[","")
                                         .replaceAll("]","")
                                         .split(",");;
 
        List<int[]> regions = new ArrayList<>();    //区间集合
        for( int i=0; i<regionsStr.length; i+=2){
            int left = Integer.valueOf(regionsStr[i]);
            int right = Integer.valueOf(regionsStr[i+1]);
            regions.add(new int[]{ left, right});
        }
 
        List<Integer> links = new ArrayList<>();    //连接器集合
        for(String s : linksStr){
            links.add(Integer.valueOf(s));
        }
 
        regions.sort((a, b) -> {    //区间进行升序排序
            if(b[0] == a[0]){
                return a[1] - b[1];
            }
            return a[0] - b[0];
        });
 
        int[] region = null;
        Iterator<int[]> iter = regions.iterator();
        while(iter.hasNext()) {
            int[] next = iter.next();
            if(region == null) {
                region = next;
            } else if(region[1] >= next[0]) {
                if(region[1] < next[1]) {
                    region[1] = next[1];
                }
                iter.remove();
            } else {
                region = next;
            }
        }
 
        List<Integer> gaps = new ArrayList<>();     //各区间所需连接器的长度集合
        iter = regions.iterator();
        region = null;
        while(iter.hasNext()) {
            int[] next = iter.next();
            if(region != null) {
                int gap = next[0] - region[1];
                gaps.add(gap);
            }
            region = next;
        }
 
        Collections.sort(gaps);
        Collections.sort(links);
 
        int i = 0; // gaps index
        int j = 0; // links index
        while(i < gaps.size() && j < links.size()) {
            if(links.get(j) >= gaps.get(i)) {   //连接器长度大于等于所需连接器长度,符合要求
                gaps.set(i, 0);     //可以连接的两个区间距离设置为0
                i++;
                j++;    //使用过的连接器不再使用
            } else {
                j++;
            }
        }
        
        int noneZoreNum = 0;
        for (int g :  gaps) {
            if(g > 0) {     //大于0,说明两个区间无法进行连接
                noneZoreNum++;
            }
        };
        System.out.println(noneZoreNum + 1);
    }
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值