-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathMain58.java
More file actions
86 lines (73 loc) · 2.28 KB
/
Main58.java
File metadata and controls
86 lines (73 loc) · 2.28 KB
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
package JZOfferTuJi;
import java.util.Map;
import java.util.TreeMap;
public class Main58 {
TreeMap<Integer, Integer> map;
public Main58() {
this.map = new TreeMap<>();
}
public boolean book(int start, int end) {
Map.Entry<Integer, Integer> entry1= map.floorEntry(start);
Map.Entry<Integer, Integer> entry2= map.ceilingEntry(start);
if (entry1 != null && entry1.getValue() > start) {
return false;
}
if (entry2 != null && entry2.getKey() < end) {
return false;
}
map.put(start, end);
return true;
}
}
/**
* 普通的二叉搜索树 (BST) 只维护了一个元素值。
* 这里让 BST 维护一个区间,即 (start, end),凡是比当前节点 start 更小的 end 所在区间应该在当前节点的左子树,
* 凡是比当前节点的 end 更大的 start 所在区间应该在当前节点的右子树。
* 这两种情况都不符合的区间即存在交集的区间,不应该被插入到树中。
*/
class MyCalendar{
class TreeNode{
TreeNode left;
TreeNode right;
int start;
int end;
public TreeNode() {
}
public TreeNode(int start, int end){
this.start = start;
this.end = end;
}
}
TreeNode root;
public MyCalendar(){
}
public boolean book(int start, int end){
if(root == null){
root = new TreeNode(start, end);
return true;
}
// 类似二分搜索BST
TreeNode p = root;
while (p != null){
if(end <= p.start){
// 该区间应该在当前节点的左子树
if(p.left == null){
// 若是左子树为空,那这就是应该插入的位置
p.left = new TreeNode(start, end);
return true;
}
p = p.left;
}else if(start >= p.end){
// 同理,该区间应该在该节点的右子树
if(p.right == null){
p.right = new TreeNode(start, end);
return true;
}
p = p.right;
}else{
return false;
}
}
return false;
}
}