46 lines
1.6 KiB
Python
46 lines
1.6 KiB
Python
# hash_table.py
|
||
# Хеш-таблица с цепочками (использует linked_list.py)
|
||
|
||
import linked_list as ll
|
||
|
||
def create_hash_table(size=1000):
|
||
"""
|
||
Создаёт пустую хеш-таблицу.
|
||
size – количество корзин (рекомендуется простое число).
|
||
"""
|
||
return [None] * size
|
||
|
||
def _hash(name, table_size):
|
||
"""Простая хеш-функция на основе суммы кодов символов."""
|
||
return sum(ord(ch) for ch in name) % table_size
|
||
|
||
def ht_insert(table, name, phone):
|
||
"""Вставляет или обновляет запись."""
|
||
idx = _hash(name, len(table))
|
||
# Вставляем в связный список в этой корзине
|
||
table[idx] = ll.ll_insert(table[idx], name, phone)
|
||
|
||
def ht_find(table, name):
|
||
"""Ищет телефон по имени."""
|
||
idx = _hash(name, len(table))
|
||
return ll.ll_find(table[idx], name)
|
||
|
||
def ht_delete(table, name):
|
||
"""Удаляет запись по имени."""
|
||
idx = _hash(name, len(table))
|
||
table[idx] = ll.ll_delete(table[idx], name)
|
||
|
||
def ht_list_all(table):
|
||
"""
|
||
Собирает все записи из всех корзин,
|
||
возвращает отсортированный по имени список.
|
||
"""
|
||
records = []
|
||
for bucket in table:
|
||
# Каждая корзина – голова связного списка
|
||
current = bucket
|
||
while current is not None:
|
||
records.append((current['name'], current['phone']))
|
||
current = current['next']
|
||
records.sort(key=lambda x: x[0])
|
||
return record |