forked from soapyigu/LeetCode-Swift
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathInsertInterval.swift
47 lines (42 loc) · 1.67 KB
/
InsertInterval.swift
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
/**
* Question Link: https://leetcode.com/problems/insert-interval/
* Primary idea: First, check if nuewInterval's start is larger than one interval's end.
* If so, save the index, otherwise save intervals
* Second, keep updating a new interval if nuewInterval's end is larger then one interval's start
* If cannot find more, append the new interval to the result array
* Final Step, append the rest intervals to the result array
*
* Time Complexity: O(n), Space Complexity: O(1),
*
* Definition for an interval.
* public class Interval {
* public var start: Int
* public var end: Int
* public init(_ start: Int, _ end: Int) {
* self.start = start
* self.end = end
* }
* }
*/
class InsertInterval {
func insert(_ intervals: [Interval], _ newInterval: Interval) -> [Interval] {
var index = 0
var result: [Interval] = []
var tempInterval = Interval(newInterval.start, newInterval.end)
while index < intervals.count && newInterval.start > intervals[index].end {
result.append(intervals[index])
index += 1
}
while index < intervals.count && newInterval.end >= intervals[index].start {
let minStart = min(tempInterval.start, intervals[index].start)
let maxEnd = max(tempInterval.end, intervals[index].end)
tempInterval = Interval(minStart, maxEnd)
index += 1
}
result.append(tempInterval)
for i in index ..< intervals.count {
result.append(intervals[i])
}
return result
}
}