-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhash_class.py
36 lines (30 loc) · 1.08 KB
/
hash_class.py
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
class HashTable():
def __init__(self):
self._size = 29
self._array = [[] for _ in range(self._size)]
def hash(self, key):
hash_key = 0
for char in key:
hash_key += ord(char)
hash_key = hash_key % self._size
return hash_key
def __setitem__(self, key, value):
hash_key = self.hash(key)
for index, item in enumerate(self._array[hash_key]):
if len(item) == 2 and item[0] == key:
self._array[hash_key][index] = (key, value)
return
self._array[hash_key].append((key, value))
def __getitem__(self, key):
hash_key = self.hash(key)
for item in self._array[hash_key]:
if item[0] == key:
return item[1]
raise KeyError(key)
def __delitem__(self, key):
hash_key = self.hash(key)
for index, item in enumerate(self._array[hash_key]):
if item[0] == key:
del self._array[hash_key][index]
return
raise KeyError(key)