博客
关于我
leetcode 986 、56 ——区间问题(数组区间的并集和交集)
阅读量:526 次
发布时间:2019-03-08

本文共 2137 字,大约阅读时间需要 7 分钟。

前缀和技巧

区间问题

区间问题主要包含两种操作:交集和并集。交集要求找到两个区间列表中同时存在的重叠部分,而并集则要求合并所有重叠的区间。

区间交集

为了解决区间交集问题,可以使用双指针法。假设输入两个已经排序的区间列表A和B,分别用两个指针i和j指向当前的区间。在每一步中,比较A[i]和B[j]的交集情况。

  • 交集条件

    • 两个区间存在交集,当且仅当A[i].start ≤ B[j].end且B[j].start ≤ A[i].end。
  • 移动指针

    • 如果满足交集条件,记录交集区间的起点和终点,注意取较大的起点和较小的终点。
    • 如果不满足交集条件,比较A[i].end和B[j].end的大小。若A[i].end较小,则将i指针向前移动(因为此时A[i]已经在B[j]之前,没有交集);否则,将j指针向前移动(因为此时B[j]已经在A[i]之前,没有交集)。
  • 代码示例

    以下是C++实现:

    #include 
    using namespace std;vector
    > intervalIntersection(vector
    > A, vector
    > B) { vector
    > res; int i = 0, j = 0; int lenA = A.size(), lenB = B.size(); while (i < lenA && j < lenB) { int a1 = A[i][0], a2 = A[i][1]; int b1 = B[j][0], b2 = B[j][1]; if (a1 <= b1 && a2 >= b1 && a1 <= b2 && a2 >= b2) { // 计算交集区间 int start = max(a1, b1); int end = min(a2, b2); res.push_back({start, end}); if (a2 < b2) { i++; } else { j++; } } else { // 不存在交集的情况 if (a2 < b1) { i++; } else { j++; } } } return res;}

    区间合并

    对于区间的并集,我们可以先按起点排序,然后用双指针法合并相邻重叠的区间。

  • 排序

    • 将区间列表按起点从小到大排序。
  • 合并步骤

    • 初始化结果列表,首先将第一个区间添加进去。
    • 对于剩下的区间,检查它是否与结果列表最后一个区间重叠。
      • 如果重叠,则更新结果列表最后一个区间的终点为当前区间的终点。
      • 如果不重叠,则将当前区间添加到结果列表的最后。
  • 代码示例

    以下是C++实现:

    #include 
    #include
    using namespace std;vector
    > merge(intervals) { vector
    > res; sort(intervals.begin(), intervals.end(), [](const vector
    & a, const vector
    & b) { return a[0] < b[0]; }); if (intervals.empty() || intervals.size() == 1) { return intervals; } res.push_back(intervals[0]); for (size_t i = 1; i < intervals.size(); ++i) { const vector
    & current = intervals[i]; const vector
    & last = res.back(); if (current[0] <= last[1]) { // 重叠的情况,更新终点 if (current[1] > last[1]) { last[1] = current[1]; } } else { // 不重叠,添加新区间 res.push_back(current); } } return res;}

    总结

    区间问题中,寻找交集和合并都是常见操作。通过双指针法,我们可以高效地解决这些问题。交集处理需仔细比较起点和终点的关系,而合并则依赖于排序后的区间列表。理解这些技巧有助于你在面对类似问题时灵活应对。

    转载地址:http://spuiz.baihongyu.com/

    你可能感兴趣的文章
    PIL&QOOT;IOERROR:带有大图像的图像文件被截断(&Q)
    查看>>
    PIL.Image、cv2的img、bytes相互转换
    查看>>
    PIL.Image进行图像融合显示(Image.blend)
    查看>>
    pilicat-dfs 霹雳猫-分布式文件系统
    查看>>
    Pillow lacks the JPEG 2000 plugin
    查看>>
    SpringBoot之ElasticsearchRestTemplate常用示例
    查看>>
    ping 全网段CMD命令
    查看>>
    ping 命令的七种用法,看完瞬间成大神
    查看>>
    Pinia入门(快速上手)
    查看>>
    Pinia:$patch的使用场景
    查看>>
    Pinia:$subscribe()的使用场景
    查看>>
    Pinpoint对Kubernetes关键业务模块进行全链路监控
    查看>>
    Pinterest 大规模缓存集群的架构剖析
    查看>>
    pintos project (2) Project 1 Thread -Mission 1 Code
    查看>>
    PinYin4j库的使用
    查看>>
    PIP
    查看>>
    pip install goose-extractor // SyntaxError: Missing parentheses in call to 'print'
    查看>>
    pip install mysqlclient报错
    查看>>
    pip install 出现报asciii码错误的解决
    查看>>
    pip throws TypeError: parse() got an unexpected keyword argument ‘transport_encoding‘ 在尝试安装新软件包时
    查看>>