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

Материал из Викиконспекты
Версия от 19:02, 10 июня 2011; 192.168.0.2 (обсуждение) (Новая страница: «При любом виде хеширования возникают коллизии. В случае открытого хеширования большое ко…»)
(разн.) ← Предыдущая | Текущая версия (разн.) | Следующая → (разн.)
Перейти к: навигация, поиск

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

Перехеширование при разных типах хеширования

При открытом типе

При использовании открытого метода, элементы с одинаковым результатом хеш-функции помещают в список. Так как операции [math]Add(x)[/math], [math]Exists(x)[/math] и [math]Delete(x)[/math] работают за [math]O(l)[/math], где [math]l[/math] - длина списка, то с некоторого момента выгодно увеличить размер хеш-таблицы, чтобы поддерживать амортизационную стоимость операции [math]O(1)[/math].

Рассмотрим следующий алгоритм перехеширования: когда в хеш-таблицу добавлено [math]\frac{4}{3}n[/math] элементов, где [math]n[/math] - размер хеш-таблицы, создадим новую хеш-таблицу размера [math]2n[/math], и последовательно переместим в нее все элементы первой таблицы. При этом, сменим хеш-функцию так, чтобы она выдавала значения [math][0..2n-1][/math] (в функциях, использующих остаток от деления на длину таблицы, достаточно брать остаток от деления на [math]2n[/math]).

Найдем амортизационную стоимость добавления, после которого было сделано перехеширование, используя метод предоплаты. С момента последнего перехеширования было произведено не менее [math]\frac{2}{3}n[/math] операций [math]Add(x)[/math], так как изначально в массиве находится [math]\frac{2}{3}n[/math] элементов (или [math]0[/math] в начале работы), а перехеширование происходит при наличии [math]\frac{4}{3}n[/math] элементов.

Для проведения перехеширования необходимо произвести [math]\frac{4}{3}n[/math] операций [math]Add(x)[/math], средняя стоимость которых составляет [math]O(1)[/math] (Анализ открытого хеширования см. Т.Корман, второе издание, стр. 288), потратить [math]\frac{4}{3}n[/math] операций на проход хеш-таблицы, и [math]\frac{4}{3}n[/math] операций на удаление предыдущей таблицы. В итоге, если мы увеличим стоимость каждой операции [math]Add(x)[/math] на [math]6[/math], то есть на [math]O(1)[/math], операция перехеширования будет полностью предоплачена. Значит, амортизационная стоимость перехеширования при открытом типе хеш-таблицы равна [math]O(1)[/math].

При закрытом типе