Created
May 14, 2024 11:15
-
-
Save lub0s/e3eb97e4de777f789ff6bbbfb3f706a9 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
class HashMap: | |
def __init__(self, size): | |
self.hashmap = [None for i in range(size)] | |
def insert(self, key, value): | |
self.resize() | |
index = self.key_to_index(key) | |
self.hashmap[index] = (key, value) | |
def resize(self): | |
old_len = len(self.hashmap) | |
if old_len == 0: | |
self.hashmap = [None] | |
return | |
load = self.current_load() | |
if load >= 0.05: | |
old_map = self.hashmap | |
self.hashmap = [None for i in range(10 * len(self.hashmap))] | |
for kv in old_map: | |
if kv is not None: self.insert(kv[0], kv[1]) | |
def current_load(self): | |
l = len(self.hashmap) | |
if l == 1: return 1 | |
not_nones = 0 | |
for i in self.hashmap: | |
if i is not None: not_nones += 1 | |
return not_nones / l | |
def key_to_index(self, key): | |
sum = 0 | |
for c in key: | |
sum += ord(c) | |
return sum % len(self.hashmap) | |
def __repr__(self): | |
final = "" | |
for i, v in enumerate(self.hashmap): | |
if v != None: | |
final += f" - {str(v)}\n" | |
return final |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment