堆相关例子-最大线段重合问题

问题描述

给定很多线段,每个线段都有两个数start, end

表示线段开始位置和结束位置,左右都是闭区间

规定:

1)线段的开始和结束位置一定都是整数值

2)线段重合区域的长度必须>=1

返回线段最多重合区域中,包含了几条线段

例如:3,10,3,4,5,9,7,13,9,10返回3

暴力方式解题

思路

先得到线段最小点和最大点,这是所有线段在x轴上的范围 在该范围上,取小数点如0.5进行查看,即查看每个0.5位置,有没有线段包含该点,记录多少条线段 max 用一个变量cover保存所有点中最多覆盖的线段条数 最后得到的cover就是重合区域最多的线段数目

图例

利用小根堆解题

思路

1.将开始点排序后,遍历该数组

2.将堆中所有 <= 当前线段的开始点的数弹出

3.将该点的结束点加入到堆中

4.记录过程中堆的历史最大长度

5.遍历结束后该长度就是其重合最多线段的个数

图例

待排序数组,且以按开始点排序

3,10,3,4,5,9,7,13,9,10

  1. 遍历到3,10
  1. 遍历到3,4
  1. 遍历到5,9

4.遍历到7,13

5.遍历到9,10

code
java 复制代码
public static int coverMax(int [][] lines){
        if(lines.length < 2)
            return 0;
        Arrays.sort(lines, (a, b) -> (a[0] - b[0]));
        PriorityQueue<Integer> minHeap = new PriorityQueue<>();
        int max = 0;
        for (int [] line : lines){
            while (!minHeap.isEmpty() && minHeap.peek() <= line[0]){
                minHeap.poll();
            }
            minHeap.add(line[1]);
            max = Math.max(max,minHeap.size());
        }
        return max;
}
相关推荐
梦@_@境12 小时前
面向 Spring Boot 的可观测业务流程编排引擎
java·spring boot·后端
云烟成雨TD12 小时前
Spring AI Alibaba 1.x 系列【77】执行取消
java·人工智能·spring
醇氧12 小时前
【Linux】Java 服务生产级部署指南:实现常驻后台、开机自启与系统服务化管理
java·开发语言
JAVA面经实录91712 小时前
Netty 全套系统化学习文档(零基础到高阶面试完整版)
java·后端
菜鸟‍12 小时前
LeetCode 1 27 和 704 || 两数之和 移除元素 二分查找
算法·leetcode·职场和发展
weixin_5231853212 小时前
Java面试高频题:Integer缓存机制与 equals、== 区别
java·缓存·面试
Hui Baby13 小时前
MCP SSE协议发送注意
java
仙俊红13 小时前
SpringBoot启动原理
java·spring boot·后端
星间都市山脉13 小时前
Android STS(Security Test Suite)完整介绍与测试流程
android·java·linux·windows·ubuntu·android studio·androidx
namexingyun13 小时前
拆解Fable 5三重安全护栏:模型路由、蒸馏防护与生物安全分类器的技术原理 - 微元算力(weytoken)
java·人工智能·python·安全·架构·ai编程