-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathLC_729_MyCalendarI.cpp
47 lines (42 loc) · 1.48 KB
/
LC_729_MyCalendarI.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
/*
https://leetcode.com/problems/my-calendar-i/
*/
class MyCalendar {
public:
/*
vector<pair<int,int>> vec;
MyCalendar() {
}
bool book(int start, int end) {
for(int i=0; i<vec.size(); i++) {
if(!(start>=vec[i].second or end<=vec[i].first))
return false;
}
vec.push_back({start, end});
return true;
}
*/
map<int,int> mp;
set<pair<int,int>> s;
MyCalendar() {
}
bool book(int start, int end) {
auto next = mp.upper_bound(start);
if(next != mp.begin() and start < prev(next)->second) return false;
if(next != mp.end() and end > next->first) return false;
mp.insert({start, end});
return true;
// // {start, end}.....lower_bound={it->first, it->second}
// auto equb = s.lower_bound({start, end}); //equal or just upper value // lower bound
// // cout<<"("<<start<<" "<<end<<") "; cout<<"("<<equb->first<<" "<<equb->second<<") "<<int(equb!=s.begin())<<" "<<int(equb!=s.end())<<endl;
// if(equb!= s.end() and end > it->first) return false; // if end then directly insert
// if(equb!= s.begin() and start < (--equb)->second) return false; // if not begin then we can shift to begin by sub
// s.insert({start, end});
// return true;
}
};
/**
* Your MyCalendar object will be instantiated and called as such:
* MyCalendar* obj = new MyCalendar();
* bool param_1 = obj->book(start,end);
*/