当前位置: 首页 > news >正文

力扣57:插入区间

力扣57:插入区间

  • 题目
  • 思路
  • 代码

题目

给你一个 无重叠的 ,按照区间起始端点排序的区间列表 intervals,其中 intervals[i] = [starti, endi] 表示第 i 个区间的开始和结束,并且 intervals 按照 starti 升序排列。同样给定一个区间 newInterval = [start, end] 表示另一个区间的开始和结束。

在 intervals 中插入区间 newInterval,使得 intervals 依然按照 starti 升序排列,且区间之间不重叠(如果有必要的话,可以合并区间)。

返回插入之后的 intervals。

注意 你不需要原地修改 intervals。你可以创建一个新数组然后返回它。

思路

这道题和56题合并区间是相同的思路,只不过一个是合并一个是插入。我们还是先思考两个区间之间存在着什么样的关系,两个区间其实只有重叠和不重叠两种关系,或者是重叠就是一个区间的左边界大于另外一个区间的左边界但是小于它的右边界,而不重叠就是一个区间的左边界大于另外一个区间的右边界或者一个区间的右边界小于另外一个区间的左边界。理清了这些关系后这道题就好做了。
那么这道题和56题不同的地方在什么呢?在于我们需要插入一个新区间所以我们必须判断什么时候插入这个新区间,其实就两种情况一是有比我们还大的区间也就是左边界都已经大于我们的右边界了或者是我们直到最后发现新区间还没有插入也就是说新区间是最后的区间的情况下。所以我们需要定义一个bool类型来判断新区间是否插入了如果在最后发现它没插入我们就需要将其插入

代码

class Solution {
public:vector<vector<int>> insert(vector<vector<int>>& intervals,vector<int>& newInterval) {int L = newInterval[0];int R = newInterval[1];vector<vector<int>> res;bool isInsert = false;for (int i = 0; i < intervals.size(); i++) {// 其实一共就三种情况// 右边界小于L,直接插入if (intervals[i][1] < L) {res.push_back(intervals[i]);}// 左边界大于R,先插入[L,R]再插入当前区间else if (intervals[i][0] > R) {if (isInsert == false) {res.push_back({L, R});isInsert = true;}res.push_back(intervals[i]);}// 右边界大于L,但是小于R或者左边界小于R但是右边界大于R,直接更新else {L = min(L, intervals[i][0]);R = max(R, intervals[i][1]);}}// 如果插入区间还没插入就说明它就是最后一个区间if (isInsert == false) {res.push_back({L, R});}return res;}
};
http://www.lryc.cn/news/625596.html

相关文章:

  • 决策树二-泰坦尼克号幸存者
  • 决策树(2)
  • FPGA入门-多路选择器
  • 决策树1.1
  • 机器学习(决策树2)
  • Leetcode 深度优先搜索 (7)
  • Python爬虫第二课:爬取HTML静态网页之《某某小说》 小说章节和内容完整版
  • 【LeetCode】3655. 区间乘法查询后的异或 II (差分/商分 + 根号算法)
  • Mybatis执行SQL流程(四)之MyBatis中JDK动态代理
  • 【HTML】3D动态凯旋门
  • Leetcode 343. 整数拆分 动态规划
  • C++入门自学Day14-- Stack和Queue的自实现(适配器)
  • 神经网络中的那些关键设计:从输入输出到参数更新
  • 面试题储备-MQ篇 3-说说你对Kafka的理解
  • 图论\dp 两题
  • 设计模式笔记_行为型_命令模式
  • 【React】事件绑定和组件基础使用
  • 从线性回归到神经网络到自注意力机制 —— 激活函数与参数的演进
  • java基础(十二)redis 日志机制以及常见问题
  • 2025年12大AI测试自动化工具
  • 多模态大模型应用落地:从图文生成到音视频交互的技术选型与实践
  • 【模块系列】STM32W25Q64
  • TDengine IDMP 运维指南(4. 使用 Docker 部署)
  • 第六天~提取Arxml中CAN物理通道信息CANChannel--Physical Channel
  • 5. Dataloader 自定义数据集制作
  • C语言基础:(十八)C语言内存函数
  • java17学习笔记-Deprecate the Applet API for Removal
  • 算法——质数筛法
  • yolov5s.onnx转rk模型以及相关使用详细教程
  • 假设检验的原理