这道题的难度跟微软的那道面试题相当。

要在集合中插入一段新的集合,相当于求两个集合的并了。对于新增加一段集合的情况,分为以下几种:

1. 增加段跟原来的全然相交,也即他的起点和终点都在被包括在原来的段中了。

这样的情况要合并这之间的段,终于增加段的起点是原来段的起点,终点是原来段的终点。

2. 增加段的起点与原来的相交。终点没有相交。终于增加的段的起点是起点相交的段的起点。终点是增加段的终点。

3. 增加段的终点与原来的相交,起点没有相交。终于增加段的起点是增加段的起点,终点是相交段的终点。

4. 增加段与原来的段没有相交。那么直接增加增加段。

在实现的时候,推断相交我用的是二分查找。对增加段的起点和终点分别查找。假设找到了的话,标记找到。并返回相交段的编号。否则的话标记未找到,返回应该插入的位置。因为函数接口要求的是返回整个更新后的段,因此除了终于增加段。要把两头的那部分没有影响到的段又一次拷贝一下。

有关后半段从哪个位置開始拷贝,分两种情况,假设终点找到了相交段,应该从相交段后面一段開始拷贝,否则的话应该从插入位置的那一段開始。

class Solution {
public:
pair<int, int> findPos(vector<Interval> &intervals, int pos, int start, int end){
if(start>end) return make_pair(0, start);
int mid = (start+end)/2;
if(intervals[mid].start<=pos&&pos<=intervals[mid].end){
return make_pair(1, mid);
}else if(intervals[mid].start>pos){
return findPos(intervals, pos, start, mid-1);
}else if(intervals[mid].end<pos){
return findPos(intervals, pos, mid+1, end);
}
return make_pair(-1, -1);
}
vector<Interval> insert(vector<Interval> &intervals, Interval newInterval) {
pair<int, int> lr, rr;
int msize = intervals.size();
vector<Interval> res;
if(msize == 0){
res.push_back(newInterval);
return res;
}
Interval intv(0, 0);
lr = findPos(intervals, newInterval.start, 0, msize-1);
rr = findPos(intervals, newInterval.end, 0, msize-1);
for(int i=0;i<lr.second;i++)
res.push_back(intervals[i]);
if(lr.first&&rr.first){
intv.start = intervals[lr.second].start;
intv.end = intervals[rr.second].end;
}else if(lr.first&&!rr.first){
intv.start = intervals[lr.second].start;
intv.end = newInterval.end;
}else if(!lr.first&&rr.first){
intv.start = newInterval.start;
intv.end = intervals[rr.second].end;
}else{
intv = newInterval;
}
res.push_back(intv);
int mstart;
if(rr.first) mstart = rr.second+1;
else mstart = rr.second;
for(int i=mstart;i<msize;i++)
res.push_back(intervals[i]);
return res;
}
};

leetcode第一刷_Insert Interval的更多相关文章

  1. leetcode第一刷_Merge Intervals

    看到这个题我就伤心啊,去微软面试的时候,第一个面试官让我做的题目就是实现集合的交操作,这个集合中的元素就像这里的interval一样.是一段一段的.当时写的那叫一个慘不忍睹.最后果然被拒掉了. .好好 ...

  2. leetcode第一刷_Set Matrix Zeroes

    这个题乍一看非常easy,实际上还挺有技巧的.我最開始的想法是找一个特殊值标记.遇到一个0,把他所相应的行列中非零的元素标记成这个特殊值.0值保持不变,然后再从头遍历一次,碰到特殊值就转化成0. 问题 ...

  3. leetcode第一刷_Permutations II

    当有反复元素的时候呢? 不用拍脑袋都会想到一种方法,也是全部有反复元素时的通用处理方法,维护一个set,假设这个元素没增加过就增加,增加过了的忽略掉.可是,在这道题上这个通用方法竟然超时了! 怎么办? ...

  4. leetcode第一刷_Populating Next Right Pointers in Each Node II

    很自然的推广,假设去掉全然二叉树的条件呢?由于这个条件不是关键,因此不会影响整体的思路.做法依旧是每次找到一层的起点,然后一层一层的走. 假设是全然二叉树的话,每层的起点就是上一层起点的左孩子,兄弟之 ...

  5. leetcode第一刷_N-Queens

    八皇后问题应该是回溯法的教学典范.在本科的时候,有一门课叫面向对象.最后的附录有这个问题的源码.当时根本不懂编程,照抄下来,执行一下出了结果都非常开心,哎. 皇后们的限制条件是不能同行同列,也不能同对 ...

  6. leetcode第一刷_Gray Code

    说到格雷码,应该没人不知道,详细它有什么用,我还真不是非常清楚,我室友应该是专家.生成的规律不是非常明显,之前看到帖子讲的,这会儿找找不到了.. 思想是这种,假设有n位,在第2^(n-1)个编码以下画 ...

  7. leetcode第一刷_Combination Sum Combination Sum II

    啊啊啊啊.好怀念这样的用递归保存路径然后打印出来的题目啊.好久没遇到了. 分了两种,一种是能够反复使用数组中数字的,一种是每一个数字仅仅能用一次的.事实上没有多大差别,第一种每次进入递归的时候都要从头 ...

  8. leetcode第一刷_Count and Say

    水题. 描写叙述的还挺麻烦的,实际上就是纸老虎,用两个string,一个存上一轮的结果,一个用来更新出这一轮的结果,每次扫描上一轮,统计一个字符出现的次数,然后把这个次数和字符增加到这一轮的字符串中就 ...

  9. leetcode第一刷_Jump Game

    这个题事实上非常easy的,我一開始想复杂了,它没要求记录路径,事实上仅仅要看一下每一步之后所能延伸到的最远的位置就能够了,在这一个最远位置前面的那些位置,都是能够到达的,假设扫到了某个i,它大于当前 ...

随机推荐

  1. Cracking The Coding Interview4.5

    //原文: // // Write an algorithm to find the 'next' node (i.e., in-order successor) of a given node in ...

  2. block,inline-block,行内元素区别及浮动

    1.block: 默认占据一行空间,盒子外的元素被迫另起一行 2.inline-block: 行内块盒子,可以设置宽高 3.行内元素: 宽度即使内容宽度,不能设置宽高,如果要设置宽高,需要转换成行内块 ...

  3. netcore 2.0 部署 到iis

    .net Core2.0应用程序发布window服务器报错容易错过的配置. 1.应用程序发布. 2.IIS上新建网站. 3.应用程序池选择无托管代码. 4.服务器上安装DotNetCore.1.0.2 ...

  4. 谈谈你对Java多线程的理解以及多线程的实现方式

    说线程之前先说进程,何为进程?进程就是正在进行中的程序.比如电脑同时在运行QQ进程.cmd进程.wps进程.飞秋进程等.在某一时刻,CPU只能执行一个程序,只是在做快速切换,我们肉眼看不出来. 比如: ...

  5. java学习笔记27(File类)

    File类: 定义:文件和目录径的抽象表示形式, Java中将路径或者文件封装成File对象 1.File类的静态成员变量 package com.zs.Demo2; import java.io.F ...

  6. tp5 生成缩略图片

    我先说下我的思路,先把正常图片存到服务器,再通过代码将服务器上的大图压缩,生成新的小图替代大图 下面上代码 前台HTML代码 <div class="upload-btn"& ...

  7. English (一)

    Phrase        do somebody a favour give sb a hand do something for sb come to sb aid  帮助某人 what can ...

  8. 判断终端是ios还是android来加载不同的样式

    <script type="text/javascript"> var addStyleLink = function(href){ var head = docume ...

  9. [转]C++智能指针简单剖析

    C++智能指针简单剖析  https://www.cnblogs.com/lanxuezaipiao/p/4132096.html 导读 最近在补看<C++ Primer Plus>第六版 ...

  10. Golang游戏服务器与skynet的个人直观比较

    我对和GOLANG写MMO服务器的一些遐想: 1.沙盒(隔离性) SKYNET:原生LUA STATE作为沙盒, 进行服务器间隔离安全性高: 服务可以很容易的配置到不同节点之上. GO:估计用RECO ...