作者:_名花侑主 | 来源:互联网 | 2023-12-11 13:49
本文介绍了解决Facebook脸书面试题中插入区间的方法,通过模拟遍历的方式判断当前元素与要插入元素的关系,找到插入点并将新区间插入。同时对算法的时间复杂度和空间复杂度进行了分析。
题目描述可以看这里
算法:模拟
只要依次遍历,判断当前元素与要插入元素的关系。
依次遍历,判断当前元素与要插入元素的关系,找到插入点,插入这个新区间
- 若是相交的,那么就停止比较,把要插入元素和当前元素合并成新区间
因为合并后的新区间也许和右边的元素有交集,会引起连锁反应,所以一直和右边的元素合并,直到无法合并为止
复杂度分析
代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
| /**
* Definition of Interval:
* public classs Interval {
* int start, end;
* Interval(int start, int end) {
* this.start = start;
* this.end = end;
* }
*/
public class Solution {
/*
* @param intervals: Sorted interval list.
* @param newInterval: new interval.
* @return: A new interval list.
*/
public List insert(List intervals, Interval newInterval) {
List newIntervals = new ArrayList();
if(intervals.size() == 0){
newIntervals.add(newInterval);
}
for (int i = 0; i // 如果新区间的结束值小于区间开始值,插在这里,后面续上
if (newInterval.end newIntervals.add(newInterval);
for (int j = i; j newIntervals.add(intervals.get(j));
}
break;
}
// 如果新区间的开始值大于区间结束值,把当前区间加进去
else if (newInterval.start > intervals.get(i).end) {
newIntervals.add(intervals.get(i));
}
// 出现交叉,需要合并
else {
newInterval.start = Math.min(newInterval.start, intervals.get(i).start);
newInterval.end = Math.max(newInterval.end, intervals.get(i).end);
}
// 最后只剩一个数据了,添加进去
if(i == intervals.size() - 1){
newIntervals.add(newInterval);
}
}
return newIntervals;
}
} |