-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathdesign_hashSet.dart
84 lines (56 loc) · 1.76 KB
/
design_hashSet.dart
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
/*
-* Design HashSet *-
Design a HashSet without using any built-in hash table libraries.
Implement MyHashSet class:
void add(key) Inserts the value key into the HashSet.
bool contains(key) Returns whether the value key exists in the HashSet or not.
void remove(key) Removes the value key in the HashSet. If key does not exist in the HashSet, do nothing.
Example 1:
Input
["MyHashSet", "add", "add", "contains", "contains", "add", "contains", "remove", "contains"]
[[], [1], [2], [1], [3], [2], [2], [2], [2]]
Output
[null, null, null, true, false, null, true, null, false]
Explanation
MyHashSet myHashSet = new MyHashSet();
myHashSet.add(1); // set = [1]
myHashSet.add(2); // set = [1, 2]
myHashSet.contains(1); // return True
myHashSet.contains(3); // return False, (not found)
myHashSet.add(2); // set = [1, 2]
myHashSet.contains(2); // return True
myHashSet.remove(2); // set = [1]
myHashSet.contains(2); // return False, (already removed)
Constraints:
0 <= key <= 106
At most 104 calls will be made to add, remove, and contains.
*/
import 'dart:typed_data';
class MyHashSet {
final Int32List mp;
MyHashSet() : mp = Int32List(125001);
void add(int key) {
final int index = key ~/ 32;
final int bitPosition = key % 32;
mp[index] |= (1 << bitPosition);
}
void remove(int key) {
final int index = key ~/ 32;
final int bitPosition = key % 32;
mp[index] &= ~(1 << bitPosition);
}
bool contains(int key) {
final int index = key ~/ 32;
final int bitPosition = key % 32;
return (mp[index] & (1 << bitPosition)) != 0;
}
}
/**
* Your MyHashSet object will be instantiated and called as such:
* MyHashSet obj = MyHashSet();
* obj.add(key);
* obj.remove(key);
* bool param3 = obj.contains(key);
*/
/*
*/