-
-
Notifications
You must be signed in to change notification settings - Fork 424
/
Copy pathRemove-Covered-Intervals.cpp
58 lines (46 loc) · 1.41 KB
/
Remove-Covered-Intervals.cpp
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
50
51
52
53
54
55
56
57
58
//Problem Statement: Remove Covered Intervals
// Given a list of intervals, remove all intervals that are covered by another interval in the list.
// Interval [a,b) is covered by interval [c,d) if and only if c <= a and b <= d.
// After doing so, return the number of remaining intervals.
//Solution:
class Solution {
public:
int removeCoveredIntervals(vector<vector<int>>& intervals) {
int ans=0;
for(int i=0; i<intervals.size(); i++) {
for(int j=0; j<intervals.size(); j++) {
if(i==j) continue;
if(intervals[i][0] >= intervals[j][0] && intervals[i][1] <= intervals[j][1]) {
// cout << i << endl;
ans++; break;
}
}
}
return intervals.size()-ans;
}
};
//Complexity: O(n*n)
SIMPLIFIED SOLUTION in O(nlogn) time
//
class Solution {
public:
int removeCoveredIntervals(vector<vector<int>>& intervals) {
sort(intervals.begin(),intervals.end(),[](vector<int>& v1,vector<int>& v2){
if(v1[0]==v2[0])
return v1[1]>v2[1];
return v1[0]<v2[0];
});
int end = intervals[0][1];
int sz = 1;
for(int i=1;i<intervals.size();i++)
{
if(intervals[i][1]>end)
{
end = intervals[i][1];
sz++;
}
}
return sz;
}
};
//