-
Notifications
You must be signed in to change notification settings - Fork 139
/
Copy pathMyCalenderIII.java
88 lines (86 loc) · 2.53 KB
/
MyCalenderIII.java
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
// https://leetcode.com/problems/my-calendar-iii/
class MyCalendarThree {
SegmentTree segmentTree;
public MyCalendarThree() {
segmentTree = new SegmentTree(0, 1000000000);
}
public int book(int start, int end) {
segmentTree.add(start, end, 1);
return segmentTree.getMax();
}
}
class SegmentTree {
TreeNode root;
public SegmentTree(int left, int right) {
root = new TreeNode(left, right);
}
public void add(int start, int end, int val) {
TreeNode event = new TreeNode(start, end);
add(root, event, val);
}
private void add(TreeNode root, TreeNode event, int val) {
if(root == null) {
return ;
}
/**
* If current node's range lies completely in update query range.
*/
if(root.inside(event)) {
root.booked += val;
root.savedres += val;
}
/**
* If current node's range overlaps with update range, follow the same approach as above simple update.
*/
if(root.intersect(event)) {
// Recur for left and right children.
int mid = (root.start + root.end) / 2;
if(root.left == null) {
root.left = new TreeNode(root.start, mid);
}
add(root.left, event, val);
if(root.right == null) {
root.right = new TreeNode(mid, root.end);
}
add(root.right, event, val);
// Update current node using results of left and right calls.
root.savedres = Math.max(root.left.savedres, root.right.savedres) + root.booked;
}
}
public int getMax() {
return root.savedres;
}
/**
* find maximum for nums[i] (start <= i <= end) is not required.
* so i did not implement it.
*/
public int get(int start, int right) {return 0;}
class TreeNode {
int start, end;
TreeNode left = null, right = null;
/**
* How much number is added to this interval(node)
*/
int booked = 0;
/**
* The maximum number in this interval(node).
*/
int savedres = 0;
public TreeNode(int s, int t) {
this.start = s;
this.end = t;
}
public boolean inside(TreeNode b) {
if(b.start <= start && end <= b.end) {
return true;
}
return false;
}
public boolean intersect(TreeNode b) {
if(inside(b) || end <= b.start || b.end <= start) {
return false;
}
return true;
}
}
}