forked from rubythonode/javascript-problems-and-solutions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmy-calendar-ii.js
72 lines (66 loc) · 2.41 KB
/
my-calendar-ii.js
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/**
* My Calendar II
*
* Implement a MyCalendarTwo class to store your events. A new event can be added if adding
* the event will not cause a triple booking.
*
* Your class will have one method, book(int start, int end). Formally, this represents a booking
* on the half open interval [start, end), the range of real numbers x such that start <= x < end.
*
* A triple booking happens when three events have some non-empty intersection (ie., there is some
* time that is common to all 3 events.)
*
* For each call to the method MyCalendar.book, return true if the event can be added to the calendar
* successfully without causing a triple booking. Otherwise, return false and do not add the event to the calendar.
*
* Your class will be called like this: MyCalendar cal = new MyCalendar(); MyCalendar.book(start, end)
*
* Example 1:
*
* MyCalendar();
* MyCalendar.book(10, 20); // returns true
* MyCalendar.book(50, 60); // returns true
* MyCalendar.book(10, 40); // returns true
* MyCalendar.book(5, 15); // returns false
* MyCalendar.book(5, 10); // returns true
* MyCalendar.book(25, 55); // returns true
*
* Explanation:
*
* The first two events can be booked. The third event can be double booked.
* The fourth event (5, 15) can't be booked, because it would result in a triple booking.
* The fifth event (5, 10) can be booked, as it does not use time 10 which is already double booked.
* The sixth event (25, 55) can be booked, as the time in [25, 40) will be double booked with the third event;
* the time [40, 50) will be single booked, and the time [50, 55) will be double booked with the second event.
*
* Note:
*
* The number of calls to MyCalendar.book per test case will be at most 1000.
* In calls to MyCalendar.book(start, end), start and end are integers in the range [0, 10^9].
*/
class MyCalendarTwo {
constructor() {
this.calendar = [];
this.overlaps = [];
}
/**
* @param {number} start
* @param {number} end
* @return {boolean}
*/
book(start, end) {
for (let interval of this.overlaps) {
if (interval[0] < end && start < interval[1]) {
return false;
}
}
for (let interval of this.calendar) {
if (interval[0] < end && start < interval[1]) {
this.overlaps.push([Math.max(start, interval[0]), Math.min(end, interval[1])]);
}
}
this.calendar.push([start, end]);
return true;
}
}
export { MyCalendarTwo };