Идеальное хеширование — различия между версиями
(→Первый уровень) |
Sultan (обсуждение | вклад) м (→Теоретическое обоснование) |
||
Строка 24: | Строка 24: | ||
|proof= | |proof= | ||
Всего имеется <tex>\dbinom{n}{2}</tex> пар ключей, которые могут вызвать коллизию. Если хеш-функция выбрана случайным образом из [[Универсальное_семейство_хеш-функций | универсального семейства хеш-функций]] <tex>H</tex>, то для каждой пары вероятность возникновения коллизии равна <tex dpi="180">{1 \over m}</tex>. Пусть <tex>X</tex> {{---}} [[Дискретная_случайная_величина |случайная величина]], которая подсчитывает количество коллизий. Если <tex>m = n^2</tex>, то [[Математическое_ожидание_случайной_величины | математическое ожидание]] числа коллизий равно | Всего имеется <tex>\dbinom{n}{2}</tex> пар ключей, которые могут вызвать коллизию. Если хеш-функция выбрана случайным образом из [[Универсальное_семейство_хеш-функций | универсального семейства хеш-функций]] <tex>H</tex>, то для каждой пары вероятность возникновения коллизии равна <tex dpi="180">{1 \over m}</tex>. Пусть <tex>X</tex> {{---}} [[Дискретная_случайная_величина |случайная величина]], которая подсчитывает количество коллизий. Если <tex>m = n^2</tex>, то [[Математическое_ожидание_случайной_величины | математическое ожидание]] числа коллизий равно | ||
− | <tex>E[X] = </tex> <tex dpi="180"> \binom{n}{2} \cdot {1 \over n^2} = {n^2-n \over | + | <tex>E[X] = </tex> <tex dpi="180"> \binom{n}{2} \cdot {1 \over n^2} = {n^2-n \over 2} \cdot {1 \over n^2} < {1 \over 2}</tex> |
}} | }} | ||
Это является очень хорошим результатом, если хотя бы вспомнить на примере [[Хеш-таблица#Введение | парадокса дней рождения]] о том, что вероятность коллизий растет крайне быстро по сравнению с размером хеш-таблицы. | Это является очень хорошим результатом, если хотя бы вспомнить на примере [[Хеш-таблица#Введение | парадокса дней рождения]] о том, что вероятность коллизий растет крайне быстро по сравнению с размером хеш-таблицы. |
Версия 09:41, 17 июня 2014
Определение: |
Идеальная хеш-функция — хеш-функция, которая без коллизий отображает различные элементы из множества объектов на множество ключей за времени в худшем случае. |
Содержание
Постановка задачи
Иногда возникают задачи не с динамическим, а со статическим множеством ключей, т.е. после того, как все ключи сохранены в таблице, их множество никогда не изменяется. При этом мы можем дополнительно хотеть, чтобы размер таблицы зависел от количества ключей линейно. Тогда мы можем использовать идеальное хеширование для обеспечения хорошей асимптотики даже в худшем случае.
Основная идея
Будем использовать двухуровневую схему хеширования с универсальным хешированием на каждом уровне.
Первый уровень
Используется тот же принцип, что и в случае хеширования с цепочками: семейства универсальных хеш-функций , где - простое число, превышающее .
ключей хешируются в ячеек с использованием хеш-функции , случайно выбранной изВторой уровень
На данном уровне вместо создания списка ключей будем использовать вторичную хеш-таблицу
, хранящую все ключи, хешированные функцией в ячейку , со своей функцией , выбранной из множества . Путем точного выбора хеш-функции мы можем гарантировать отсутствие коллизий на этом уровне. Для этого требуется, чтобы размер хеш-таблицы был равен квадрату числа ключей, хешированных функцией в ячейку .Несмотря на квадратичную зависимость, ниже будет показано, что при корректном выборе хеш-функции первого уровня количество требуемой для хеш-таблицы памяти будет
.Теоретическое обоснование
Теорема: |
Если универсального множества хеш-функций, то вероятность возникновения коллизий не превышает . ключей сохраняются в хеш-таблице размером c использованием хеш-функции , случайно выбранной из |
Доказательство: |
Всего имеется универсального семейства хеш-функций , то для каждой пары вероятность возникновения коллизии равна . Пусть — случайная величина, которая подсчитывает количество коллизий. Если , то математическое ожидание числа коллизий равно пар ключей, которые могут вызвать коллизию. Если хеш-функция выбрана случайным образом из |
Это является очень хорошим результатом, если хотя бы вспомнить на примере парадокса дней рождения о том, что вероятность коллизий растет крайне быстро по сравнению с размером хеш-таблицы.
Теорема: |
Если мы сохраняем ключей в хеш-таблице в хеш-таблице размеров c использованием хеш-функции , выбираемой случайным образом из универсального множества хеш-функций, то , где — количество ключей, хешированных в ячейку . |
Доказательство: |
Первый переход в равенстве мы совершили благодаря формуле математического ожидания, в частности - линейности. . Далее мы воспользовались свойствамиОчевидно, что - просто общее количество коллизий, поэтому по свойству универсального хеширования математическое ожидание значения этой суммы не превышает А так как , то , ч.т.д. |
Теперь выведем 2 следствия из этой теоремы.
Теорема: |
Если мы сохраняем универсального множества хеш-функций, и устанавливаем размер каждой вторичной хеш-таблицы равным , то математическое ожидание количества необходимой для вторичных хеш-таблиц в схеме идеального хеширования памяти не превышает . ключей в хеш-таблице размером с использованием хеш-функции , выбираемой случайным образом из |
Доказательство: |
Поскольку для , согласно предыдущей теореме: , ч.т.д. |
Теорема: |
Если мы сохраняем универсального множества хеш-функций, и устанавливаем размер каждой вторичной хеш-таблицы равным , то вероятность того, что общее количество необходимой для вторичных хеш-таблиц памяти не менее , меньше чем . ключей в хеш-таблице размером с использованием хеш-функции , выбираемой случайным образом из |
Доказательство: |
Применим неравенство Маркова Пусть Тогда и . , ч.т.д. |
См. также
Ссылки
- Т. Кормен. «Алгоритмы. Построение и анализ» второе издание, Глава 11.5, стр. 308
- Д.Э. Кнут. «Искусство программирования: Сортировка и поиск" Том 3, Глава 6.4, стр. 563
- Perfect hash function — Wikipedia
- Universal and Perfect Hashing
- Универсальное хэширование. Идеальное хэширование