博客
关于我
LeetCode 435 无重叠区间 HERODING的LeetCode之路
阅读量:167 次
发布时间:2019-02-28

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

为了解决这个问题,我们需要找到最小的移除数量,使得剩下的区间互不重叠。我们可以使用贪心算法来解决这个问题,具体步骤如下:

方法思路

  • 排序区间:首先将所有区间按照右端点从小到大排序。这样可以确保我们总是优先考虑右端点较小的区间,这样有助于减少后续区间的重叠可能性。
  • 遍历区间:从左到右遍历这些排序后的区间。对于每个区间,如果它的左端点不小于当前记录的右端点,则保留这个区间,并更新当前记录的右端点。否则,该区间与已保留的区间重叠,需要移除。
  • 计算移除数量:最后,移除的数量等于总区间数减去保留的区间数。
  • 这种方法的时间复杂度主要是排序的时间复杂度 O(n log n),其中 n 是区间的数量。遍历的时间复杂度是 O(n),因此整体复杂度为 O(n log n),能够高效地处理问题。

    解决代码

    #include 
    #include
    using namespace std;int eraseOverlapIntervals(vector
    >& intervals) { if (intervals.empty()) return 0; sort(intervals.begin(), intervals.end(), [](const vector
    & a, const vector
    & b) { return a[1] < b[1]; }); int n = intervals.size(); int right = -1; int count = 0; for (const auto& interval : intervals) { if (interval[0] >= right) { right = interval[1]; count++; } } return n - count;}

    代码解释

  • 排序区间:使用 sort 函数对区间列表进行排序,排序依据是区间的右端点。
  • 初始化变量right 用于记录当前保留的区间的右端点,初始化为 -1。count 用于记录保留的区间数量,初始化为 0。
  • 遍历区间:对于每个区间,检查其左端点是否大于等于 right。如果是,说明该区间不与已保留的区间重叠,可以保留,并更新 right 为该区间的右端点,同时增加 count
  • 计算结果:最后,返回移除的区间数量,计算方式为总区间数减去保留的区间数量。
  • 这种方法确保了我们以最优的方式选择区间,移除尽可能少的区间,从而得到一个互不重叠的区间集合。

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

    你可能感兴趣的文章
    Oracle收购DataScience.com扩展云平台分析能力
    查看>>
    Oracle教程之管理索引(七)--Oracle显示索引信息
    查看>>
    oracle数据库 添加定时器
    查看>>
    Oracle数据库DBA日常Sql列表
    查看>>
    Oracle数据库ORA-01555解决含clob和blob字段表报错快照过旧问题
    查看>>
    ubuntu24 finalshell 无法连接ubuntu服务器, 客户端无法连接ubuntu, 无法远程连接ubuntu。
    查看>>
    Oracle数据库入门——初级系列教程
    查看>>
    oracle数据库包package小例子
    查看>>
    UBUNTU 添加删除用户
    查看>>
    Oracle数据库备份与还原
    查看>>
    Ubuntu Seata开机自启动服务
    查看>>
    uart 驱动架构
    查看>>
    Oracle数据库学习(三)
    查看>>
    Oracle数据库安装成功后,忘记解锁账户和设置密码
    查看>>
    TypeError: create_purple() 接受 0 个位置参数,但给出了 2 个
    查看>>
    Oracle数据库异常--- oracle_10g_登录em后,提示java.lang.Exception_Exception_in_sending_Request__null或Connection
    查看>>
    Oracle数据库异常---OracleDBConsoleorcl无法启动
    查看>>
    oracle数据库异常---SP2-1503: 无法初始化 Oracle 调用界面 SP2-1503: 无法初始化 Oracle 问题的解决办法
    查看>>
    Oracle数据库性能调优
    查看>>
    oracle数据库核心笔记
    查看>>