LeetCode面试题Day16|LC56 合并区间、LC57 插入区间

2024-08-24 05:36

本文主要是介绍LeetCode面试题Day16|LC56 合并区间、LC57 插入区间,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目一:

指路:

. - 力扣(LeetCode)56 合并区间

思路与分析:

本题题意清晰易懂,当区间有重叠元素时返回能覆盖这些重叠区间的大区间,否则就返回无重叠区间。那么判断区间是否有重叠只需要按照区间各自的左边界升序排序,如果前一个区间的右边界大于后一个区间的左边界时则说明当前两区间有重叠元素。那么在将答案添加进结果集时,按照区间左边界升序之后,第一个区间的左边界一定是最小的,可以直接添加进结果集,那么添加右边界时需要判断判断一下哪个区间有较大的右边界,返回即可,最后添加无重叠元素的单个区间。

代码:

class Solution {static bool cmp(vector<int>& a, vector<int>& b) {return a[0] < b[0];  // 根据左边界排序}
public:vector<vector<int>> merge(vector<vector<int>>& intervals) {vector<vector<int>> result;  // 最终结果集vector<int> path;if (intervals.size() == 0) return result;sort(intervals.begin(), intervals.end(), cmp);result.push_back(intervals[0]);  // for (int i = 1; i < intervals.size(); i++) {if (result.back()[1] >= intervals[i][0]) {  //// 末尾元素的右边界 >= 当前元素左边界(两区间有重叠)result.back()[1] = max(result.back()[1], intervals[i][1]);// 右边界 = 最大的右边界} else {result.push_back(intervals[i]);  // 无重叠的区间}}return result;}
};

题目二:

指路:

. - 力扣(LeetCode)57 插入区间

思路与分析:

本题中,我们可以读出的信息是:1.给定的若干个区间无重叠(上一个区间的右边界小于下一个区间的左边界);2.给定的若干个区间已经按照左边界升序排序;3.需要在给定的区间插入给定的新区见使插入后的区间依旧按照左边界排序同时各个区间无重叠(这就要求加入的区间左边界大于原某一区间的右边界而加入区间的右边界小于原某一区间的左边界);4.必要时可以合并区间意为当与第三条发生冲突时将两区间合并得到一个新区间从而满足第三条。那么我们将原区间与加入区间的情况分为以下几种,原某一区间在加入区间的右侧,当需要加入的区间还未加入时,那么我们可以直接加入需要加入的区间继而加入原区间的左右区间;又或是原区间在需要加入区间的左边二者依旧无重叠,此时返回原区间的左右边界继而返回新加入区间的左右边界;最后是两区间有重叠,此时需要返回较小的左边界和较大的右边界。

代码:

class Solution {
public:vector<vector<int>> insert(vector<vector<int>>& intervals, vector<int>& newInterval) {vector<vector<int>> ans;bool placed = false;for (int i = 0; i < intervals.size(); i++) {if (intervals[i][0] > newInterval[1]) {  // 在插入区间的右侧无重叠if (!placed) {  // ans.push_back({newInterval[0], newInterval[1]}); placed = true;} ans.push_back({intervals[i][0], intervals[i][1]});} else if (intervals[i][1] < newInterval[0]) {  // 无重叠ans.push_back({intervals[i][0], intervals[i][1]});} else {  // 返回较小左边界和较大右边界newInterval[0] = min(newInterval[0], intervals[i][0]);newInterval[1] = max(newInterval[1], intervals[i][1]);}}if (!placed) {  // ans.push_back({newInterval[0], newInterval[1]});}return ans;}
};

这篇关于LeetCode面试题Day16|LC56 合并区间、LC57 插入区间的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1101592

相关文章

Python中bisect_left 函数实现高效插入与有序列表管理

《Python中bisect_left函数实现高效插入与有序列表管理》Python的bisect_left函数通过二分查找高效定位有序列表插入位置,与bisect_right的区别在于处理重复元素时... 目录一、bisect_left 基本介绍1.1 函数定义1.2 核心功能二、bisect_left 与

解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction

《解决mysql插入数据锁等待超时报错:Lockwaittimeoutexceeded;tryrestartingtransaction》:本文主要介绍解决mysql插入数据锁等待超时报... 目录报错信息解决办法1、数据库中执行如下sql2、再到 INNODB_TRX 事务表中查看总结报错信息Lock

Python中合并列表(list)的六种方法小结

《Python中合并列表(list)的六种方法小结》本文主要介绍了Python中合并列表(list)的六种方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录一、直接用 + 合并列表二、用 extend() js方法三、用 zip() 函数交叉合并四、用

利用Python实现Excel文件智能合并工具

《利用Python实现Excel文件智能合并工具》有时候,我们需要将多个Excel文件按照特定顺序合并成一个文件,这样可以更方便地进行后续的数据处理和分析,下面我们看看如何使用Python实现Exce... 目录运行结果为什么需要这个工具技术实现工具的核心功能代码解析使用示例工具优化与扩展有时候,我们需要将

Python实现获取带合并单元格的表格数据

《Python实现获取带合并单元格的表格数据》由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,所以本文我们就来聊聊如何使用Python实现获取带合并单元格的表格数据吧... 由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,现将将封装成类,并通过调用list_exc

SpringBoot整合mybatisPlus实现批量插入并获取ID详解

《SpringBoot整合mybatisPlus实现批量插入并获取ID详解》这篇文章主要为大家详细介绍了SpringBoot如何整合mybatisPlus实现批量插入并获取ID,文中的示例代码讲解详细... 目录【1】saveBATch(一万条数据总耗时:2478ms)【2】集合方式foreach(一万条数

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

Python实现合并与拆分多个PDF文档中的指定页

《Python实现合并与拆分多个PDF文档中的指定页》这篇文章主要为大家详细介绍了如何使用Python实现将多个PDF文档中的指定页合并生成新的PDF以及拆分PDF,感兴趣的小伙伴可以参考一下... 安装所需要的库pip install PyPDF2 -i https://pypi.tuna.tsingh

Jmeter如何向数据库批量插入数据

《Jmeter如何向数据库批量插入数据》:本文主要介绍Jmeter如何向数据库批量插入数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Jmeter向数据库批量插入数据Jmeter向mysql数据库中插入数据的入门操作接下来做一下各个元件的配置总结Jmete

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://