Задание 5. Хеш-таблица
Реализуйте словарь (он же ассоциативный массив или Map) на основе хеш-таблицы. Для разрешения коллизий используйте метод цепочки: когда в таблице хранятся указатели на связные списки.
Для таблицы используйте std::vector
, для списка пар std::list
.
Алгоритм хеширования строк:
constexpr size_t P = 300007; // Размер таблицы. Ближайшее простое > 3*100000
constexpr size_t A = 31; // Простое и не меньше размера алфавита
size_t hash_str(const std::string& value) {
size_t h = 0;
for (char ch : value) {
h = (h * A + ch) % P;
}
return h;
}
Входные данные
На вход программы подаются команды, их количество не превышает 100_000. В каждой строке находится одна из команд:
put k v
— сохранить ключk
и значениеv
таблицу. Если ключk
уже существует, то перезаписать значение на новоеv
.delete k
— удалить ключ k из таблицы и соответсвующее ему значениеv
.get k
— вывести в консоль значениеvalue
по ключуk
. Если ключа нет, то вывести строкуnull
.
Тип данных k
и v
— string. Значения k
и v
не соджержат пробельных символов.
Гарантируется, что некорректные команды подаваться НЕ будут.
Выходные данные
Вывести результаты вызова команд get
. Каждый результат на новой строке.
Пример
Вход
put hello world
put name ilya
get hello
get ilya
delete hello
get hello
get name
put name vasya
get name
Выход
world
null
null
ilya
vasya