WikiDer > Статическое хеширование

Static hashing

Статическое хеширование это еще одна форма хеширование проблема, которая позволяет пользователям выполнять поиск в окончательном наборе словарей (все объекты в словаре являются окончательными и не меняются).

Применение [1]

заявка

Поскольку статическое хеширование требует, чтобы база данных, его объекты и ссылки остаются прежними, его приложения ограничены. Базы данных, которые содержат информацию, которая редко изменяется, также имеют право, так как в редких случаях потребуется полное повторное хеширование всей базы данных. Примеры этого включают наборы слов и определений конкретных языков, наборы важных данных для персонала организации и т. Д.

Идеальное хеширование

Идеальное хеширование - это модель хеширования, в которой любой набор из n элементов может храниться в хеш-таблица одинакового размера и может выполнять поиск в постоянное время. Он был специально открыт и обсужден Фредманом, Комлосом и Семереди (1984) и поэтому получил прозвище «FKS Hashing».[2]

FKS хеширование

FKS Hashing использует хеш-таблицу с двумя уровнями, в которой верхний уровень содержит n сегментов, каждая из которых содержит свою собственную хеш-таблицу. FKS-хеширование требует, чтобы в случае возникновения коллизий они происходили только на верхнем уровне.

Реализация

Верхний уровень содержит случайно созданную хэш-функцию h (x), которая соответствует ограничениям хеш-функции Картера и Вегмана, как показано на Универсальное хеширование. После этого на верхнем уровне должно быть n контейнеров с меткой k1, k2, k3, ..., кп. Следуя этому шаблону, все сегменты содержат хеш-таблицу размера s.я и соответствующая хеш-функция hя(Икс). Хеш-функция будет определяться установкой sя кя2 и случайным образом перебираем функции, пока не исчезнут коллизии. Это можно сделать за постоянное время.

Спектакль

Потому что есть Для пар элементов, вероятность коллизии которых равна 1 / n, при хешировании FKS может быть строго меньше, чем n / 2 коллизий. Исходя из этого факта и того, что каждый h (x) был выбран так, чтобы количество коллизий было не больше n / 2, размер каждой таблицы на нижнем уровне не будет больше 2n.

Смотрите также

использованная литература

  1. ^ Даниэль Рош (2013). SI486D: Случайность в вычислениях, блок хеширования. Военно-морская академия США, факультет компьютерных наук.
  2. ^ Майкл Фредман; Янош Комлос; Эндре Семереди (1984). Хранение разреженной таблицы с O (1) наихудшим временем доступа. Журнал ACM (том 31, выпуск 3).