力扣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.pswp.cn/bicheng/93890.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/93890.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

KVM虚拟化技术解析:从企业应用到个人创新的开源力量

1 .KVM&#xff1a;开源虚拟化的核心引擎 KVM&#xff08;Kernel-based Virtual Machine&#xff09;作为Linux内核原生集成的开源虚拟化模块&#xff0c;彻底改变了现代数据中心的虚拟化格局。它通过将Linux内核转变为Type-1型虚拟机监控器&#xff08;Hypervisor&#xff09;…

28.Linux :通过源代码编译安装lamp

Linux &#xff1a;通过源代码编译安装lamp 区别特性源代码编译安装yum 安装安装方式从源代码编译构建预编译的二进制包自定义程度高度可定制有限定制性能优化可针对特定硬件优化通用优化依赖管理手动解决依赖关系自动解决依赖安装复杂度复杂&#xff0c;需技术经验简单&#x…

应用控制技术

一、 应用特征识别技术1.传统行为检测技术1.1 五元组检测原理1.2 配置思路1.3 效果展示需求背景21.4 传统行为检测的缺陷无法识别应用层内容&#xff1a;若应用更换端口&#xff08;如QQ改用随机端口&#xff09;或伪装协议&#xff08;如HTTPS加密&#xff09;&#xff0c;传统…

当MySQL的int不够用了

关于int的长度很多时候看到int(8)这样的定义&#xff0c;其实这是工具导出的不专业。int是范围&#xff0c;不是长度。在开发有了共识&#xff08;知道这个长度不算数&#xff0c;要看范围&#xff09;以后&#xff0c;上来就是所有的类型都是bigint。int的范围int的取值范围是…

让AI学会“边做边想“:ReAct的实战指南

小智的求职困境有个叫小智的AI助手&#xff0c;它刚从"大语言模型大学"毕业&#xff0c;满怀信心地去应聘一家咨询公司的智能助理职位。面试官问&#xff1a;"北京和上海哪个城市人口更多&#xff1f;"小智立刻回答&#xff1a;"根据我的知识&#xf…

vue优化有哪些手段?

vue本身存在的方法 v-if 和v-show 的合理运用,频繁使用的组件使用v-show,不频繁的使用v-if,来减少dom的渲染路由懒加载 采用()>import(index.vue)当路由被访问的时候才回去加载使用keep-alive缓存页面,减少没必要的重复渲染同时也可以减少服务器的压力使用computed缓存数据,…

【图像算法 - 14】精准识别路面墙体裂缝:基于YOLO12与OpenCV的实例分割智能检测实战(附完整代码)

摘要&#xff1a; 裂缝是结构健康的重要隐患&#xff0c;传统人工巡检耗时耗力且易遗漏。本文将带您利用当前最先进的YOLO12实例分割模型&#xff0c;构建一个高效、准确、更高精度的裂缝检测系统。我们将从数据准备、模型训练到结果可视化&#xff0c;手把手实现一个完整的项目…

“让机器人更智慧 让具身体更智能”北京世界机器人大会行业洞察

2025年8月8日&#xff0c;世界机器人大会在北京盛大开幕。本届大会以“让机器人更智慧 让具身体更智能”为主题&#xff0c;由中国电子学会、世界机器人合作组织主办&#xff0c;包括开幕式、闭幕式、论坛等。同期举办世界机器人博览会、世界机器人大赛等活动&#xff0c;打造了…

PHP如何使用JpGraph生成折线图?

JpGraph是一个功能强大的PHP图表库&#xff0c;它通过封装GD库函数&#xff0c;为开发者提供了简单高效的数据可视化解决方案。作为专门用于绘制统计图的面向对象库&#xff0c;JpGraph支持创建折线图、柱状图、饼图等20余种图表类型&#xff0c;并能自动处理坐标轴、刻度、图例…

超级云平台:重构数字生态的“超级连接器“

在数字经济浪潮席卷全球的今天,企业数字化转型已从"选择题"变为"必答题"。然而,传统云服务模式因技术壁垒高、资源分散、协同效率低等问题,让许多企业在数字化转型中陷入"上云易、用云难"的困境。 在此背景下,一种以"全域资源整合+智能…

https如何保证传递参数的安全

HTTPS 并非直接“加密参数”&#xff0c;而是通过一整套加密传输机制&#xff0c;确保客户端与服务器之间所有通信内容&#xff08;包括 URL 参数、表单数据、Cookie 等&#xff09;在传输过程中不被窃听、篡改或伪造。其核心安全保障来自以下技术实现&#xff1a; 一、核心加密…

OpenHarmony之打造全场景智联基座的“分布式星链 ”WLAN子系统

1. 技术架构概览 无线局域网(Wireless Local Area Networks,WLAN),是通过无线电、红外光信号或者其他技术发送和接收数据的局域网,用户可以通过WLAN实现结点之间无物理连接的网络通讯。常用于用户携带可移动终端的办公、公众环境中。 WLAN组件子系统为用户提供WLAN基础功…

JMeter(入门篇)

一.简介 JMeter 是 Apache 组织使用 Java 开发的一款测试工具。 1、可以用于对服务器、网络或对象模拟巨大的负载 2、通过创建带有断言的脚本来验证程序是否能返回期望的结果 二.优缺点 优点&#xff1a; 开源、免费 跨平台 支持多协议 小巧 功能强大 缺点&#xff…

Lecture 12: Concurrency 5

回顾&#xff1a;并行用餐哲学家读者/作者问题哲学家进餐问题方案三&#xff1a;最大化并行需要一个更复杂的解决方案来实现最大的并行性 解决方案使用&#xff1a;state[N]&#xff1a;每个哲学家的当前状态&#xff08;THINKING&#xff0c; HUNGRY&#xff0c; EATING&#…

UniApp 微信小程序之间跳转指南

概述 在UniApp开发中&#xff0c;经常需要实现从当前小程序跳转到其他微信小程序的功能。本文档详细介绍了如何在UniApp中实现微信小程序之间的跳转。 核心API uni.navigateToMiniProgram() 这是UniApp提供的用于跳转到其他微信小程序的核心API。 基本语法 uni.navigateToMiniP…

基于SpringBoot+Vue的养老院管理系统的设计与实现 智能养老系统 养老架构管理 养老小程序

&#x1f525;作者&#xff1a;it毕设实战小研&#x1f525; &#x1f496;简介&#xff1a;java、微信小程序、安卓&#xff1b;定制开发&#xff0c;远程调试 代码讲解&#xff0c;文档指导&#xff0c;ppt制作&#x1f496; 精彩专栏推荐订阅&#xff1a;在下方专栏&#x1…

TRAE调教指南:用6A工作流项目规则+5S敏捷个人规则打造高效AI开发流程

TRAE调教指南&#xff1a;用6A工作流项目规则5S敏捷个人规则打造高效AI开发流程 引言&#xff1a;从"AI瞎写"到"精准交付"的实战手册一、什么是Rules&#xff1a;让AI"听话"的底层逻辑1. 告别重复指令疲劳2. 实现"千人千面"的个性化适…

【C语言】gets和getchar的区别

在C语言中&#xff0c;gets和getchar是两个用于输入的标准函数&#xff0c;它们在功能和用法上有所不同。 功能上&#xff1a; gets函数主要用于读取一行字符串&#xff0c;直到遇到换行符&#xff08;回车键&#xff09;为止。它会自动过滤掉换行符&#xff0c;不会将其读入到…

【数据结构与算法】数据结构初阶:详解二叉树(一)

&#x1f525;个人主页&#xff1a;胡萝卜3.0 &#x1f3ac;作者简介&#xff1a;C研发方向学习者 &#x1f4d6;个人专栏&#xff1a; 《C语言》《数据结构》 《C干货分享》 ⭐️人生格言&#xff1a;不试试怎么知道自己行不行 正片开始之前&#xff0c;我们来了解一下我们即…

工具测试 - marker (Convert PDF to markdown + JSON quickly with high accuracy)

参考链接如下&#xff1a;&#xff1a; 参考链接&#xff1a;https://github.com/datalab-to/marker?tabreadme-ov-file#llm-services 底层的OCR模型&#xff1a;https://github.com/datalab-to/surya 作用&#xff1a;开源免费&#x1f193;&#xff0c;多 GPU 推理、生成效…