|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 Judie 于 2023-5-29 19:37 编辑
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 <= 10^6
At most 10^4 calls will be made to add, remove, and contains.
Judy
Pythonclass MyHashSet(object):
def __init__(self):
self.set = set()
def add(self, key):
"""
:type key: int
:rtype: None
"""
self.set.add(key)
def remove(self, key):
"""
:type key: int
:rtype: None
"""
if key in self.set:
self.set.remove(key)
def contains(self, key):
"""
:type key: int
:rtype: bool
"""
return key in self.set
# Your MyHashSet object will be instantiated and called as such:
# obj = MyHashSet()
# obj.add(key)
# obj.remove(key)
# param_3 = obj.contains(key)
Mike
C++ a little bit better class MyHashSet {
public:
unordered_map<int, bool> hash;
MyHashSet() {
hash = {};
}
void add(int key) {
hash[key] = true;
}
void remove(int key) {
hash.erase(key);
}
bool contains(int key) {
return !(hash.find(key) == hash.end());
}
};
Gray
C++ class MyHashSet {
public:
MyHashSet() {
}
map<int,int> hashmap;
void add(int key) {
hashmap[key] = 1;
}
void remove(int key) {
hashmap[key] = 0;
}
bool contains(int key) {
if(hashmap.find(key)!=hashmap.end() && hashmap[key]==1){
return true;
}else {
return false;
}
}
};
|
|