Insert Interval
Given a set ofnon-overlappingintervals, insert a new interval into the intervals (merge if necessary).
You may assume that the intervals were initially sorted according to their start times.
Example 1:
Given intervals[1,3],[6,9]
, insert and merge[2,5]
in
as[1,5],[6,9]
.
Example 2:
Given[1,2],[3,5],[6,7],[8,10],[12,16]
, insert and merge[4,9]
in
as[1,2],[3,10],[12,16]
.
This is because the new interval[4,9]
overlaps with[3,5],[6,7],[8,10]
.
这样的题目应该可以归类,归类到麻烦题。
因为这样的题思想不难,但是却很繁琐。
要提高两个能力:
1 处理下标的能力
2 构造判断结束条件的能力。尤其是这道题看起来“简单”的题目,构造这些判断条件居然无比复杂。
这让我想起了不久前网上看到有人说他半个小时刷了8道leetcode题,我着实大吃一惊。这个世界上居然有这号人物?这样的人年薪不过百万,实在是没天理了。
但是想想这应该不可能,虽然我无法去查证,但是我做这道题的时候也在想十来分钟搞定了,因为思路就两分钟出来,但是因为各种小问题,到最后程序出来,吃透,优化好,居然搞了我几个小时。
也就是说如果做leetcode题,光写解法,不写程序的话,那么半个小时10题以上都没问题,但是如果要写出AC的程序的话,随便挑题,也不大可能半个小时8道题吧。
当然不排除有天才,如果有,麻烦证明一下给我看,让我开开眼界,O(∩_∩)O~。
下面是我认为最简洁清晰的程序了:
/**
* Definition for an interval.
* struct Interval {
* int start;
* int end;
* Interval() : start(0), end(0) {}
* Interval(int s, int e) : start(s), end(e) {}
* };
*/
class Solution {
public:
//条件太多,每一个大小等号比较,每一个小下标就能让人栽跟斗。
vector<Interval> insert(vector<Interval> &v, Interval nv)
{
vector<Interval> res;
int sta = nv.start, end = nv.end;
int i = 0;
//注意:找到第一个起点的条件
for (; i<v.size() && sta > v[i].end; i++)
{
res.push_back(v[i]);
}
//注意:为空或过了结尾点
if (i<v.size())
sta = min(sta, v[i].start);
//注意:找到结束点的条件
for (; i<v.size() && end >= v[i].start; i++)
end = max(end, v[i].end);
res.push_back(Interval(sta, end));
res.insert(res.end(), v.begin()+i, v.end());
return res;
}
};
2014-1-29 update
锻炼了思维,本题也不是那么困难的,找到规律还要找到很好的处理方法就行。
重做了下,可以10分钟内做出来了。
vector<Interval> insert(vector<Interval> &v, Interval nv)
{
vector<Interval> rs;
int i = 0;
for ( ; i < v.size() && v[i].end < nv.start; i++)
{
rs.push_back(v[i]);
}
if (i == v.size())
{
rs.push_back(nv);
return rs;
}
nv.start = min(nv.start, v[i].start);
for ( ; i < v.size() && v[i].start <= nv.end; i++)
{
nv.end = max(nv.end, v[i].end);
}
rs.push_back(nv);
for ( ; i < v.size(); i++)
{
rs.push_back(v[i]);
}
return rs;
}
分享到:
相关推荐
java java_leetcode题解之Insert Interval.java
js js_leetcode题解之57-insert-interval.js
* Insert Interval:该题目要求将一个区间插入到另一个区间中,实现方法使用了排序和迭代算法。 三、字符串和动态规划 * String to Integer (atoi):该题目要求将字符串转换成整数,实现方法使用了状态机算法。 * ...
# [LeetCode](https://leetcode.com/problemset/algorithms/) ![Language](https://img.shields.io/badge/language-Python%20%2F%20C++%2011-orange.svg) [![License]...
5. **Merge Intervals(using (Insert Interval) ).cpp** - 这是第56题“合并区间”的解冑,涉及到区间操作,尤其是如何有效地插入新区间并合并重叠区间。 6. **Integer to Roman.cpp** - 第40题,与“Roman to ...
10. Insert Interval 区间插入是一个数组问题,要求将一个区间插入到已经排序的区间数组中。可以使用二分搜索来解决该问题。 11. Two Sum 两数之和是一个经典的数组问题,要求找到数组中两个元素之和等于目标值的...
- Insert Interval: 在一组已经排序的区间中,插入一个新的区间。 - Rotate List: 给定一个链表的头节点head,当旋转了k个位置后,返回链表的新头节点。 - Unique Paths / Unique Paths II: 前者计算从矩阵的左上角...
在本资源包中,我们关注的是C语言的学习以及如何通过LeetCode平台进行编程练习,特别是针对第57题“插入区间”(Insert Interval)的解题方法。LeetCode是一个在线平台,提供了各种算法题目,旨在帮助程序员提升技能...
颜色分类leetcode leetcode.etc My solutions of the problems in Online judge website, leetcode, lintcode, etc. leetcode: 13 ...Insert Interval Easy Two Strings Are Anagrams(比较字符串) E
Interval 解决方法:遍历 LeetCode: 229. Majority Element II 解决方法:Majority Voting算法的变种。但是最终的算法实现形式,很难理解。 2018-08-19 19:16 LeetCode: 79. Word Search 解决方法:DFS LeetCode: 31...
第57题,"插入区间"(Insert Interval),是其中一道挑战性较高的问题,旨在检验开发者对区间操作、数据结构以及排序算法的理解。下面将详细探讨这个问题的背景、解题策略以及相关的C++编程知识点。 问题描述: ...
def insert(self, intervals, new_interval): intervals.append(new_interval) intervals.sort(key=lambda x: x.start) merged_intervals = [] for interval in intervals: if not merged_intervals or ...
leetcode 力码 【吾生也有涯,而知也无涯。】 刷题解题记录: 大批: 220 包含重复 III 考 55 跳跃游戏45 跳跃游戏 II121 买卖股票的最佳时机 122 买卖股票的最佳时机 II123 买卖股票的最佳时机 III188 买卖股票的...
12 Insert Interval 45 13 Two Sum 47 14 Two Sum II Input array is sorted 49 15 Two Sum III Data structure design 51 16 3Sum 53 17 4Sum 55 18 3Sum Closest 57 19 String to Integer (atoi) 59 20 Merge ...