Kuckucks-Hashing

Kuckucks-Hashing (englisch cuckoo hashing) ist ein Algorithmus, der mittels zweier Hashfunktionen den Index in einer Tabelle berechnet, an dem das Element eingefügt werden soll. Er wurde 2001 von Rasmus Pagh und Flemming Friche Rodler entwickelt.[1] Seinen Namen hat er von dem Kuckuck, der seine Eier in fremde Nester legt und dessen Küken die Eier der Wirtseltern aus dem Nest stoßen.

Funktionsweise

Jede der beiden Hashfunktionen berechnet den Index eines einzufügenden Elementes jeweils für eine Tabelle. Zuerst wird geprüft, ob das einzufügende Element mit der Hashfunktion in die Tabelle an der Stelle eingefügt werden kann. Ist das der Fall, dann wird das Element dort eingefügt. Wenn der Platz jedoch schon belegt ist, dann wird mit der zweiten Hashfunktion der Platz in der zweiten Tabelle berechnet und, wenn dieser frei ist, dort eingefügt. Ist jedoch der Platz auch belegt, wird das einzufügende Element in die erste Tabelle eingefügt und das Element, das dort vorher war, in die zweite Tabelle verschoben. Wenn nun dort wieder eine Kollision auftritt, dann wird das Element von dort wieder in die erste Tabelle verlegt. Ist der Platz in der ersten Tabelle frei, ist das Einfügen beendet. Sollte jedoch auch hier wieder ein Element den Platz belegen, dann wird es wieder in die zweite Tabelle verschoben. Dieses Verfahren wiederholt man so lange, bis ein freier Platz gefunden wurde. Es kann jedoch vorkommen, dass die gleiche Tabellenkonstellation wie zu Beginn auftritt, damit gerät das Verfahren dann in einen Zyklus (Endlosschleife). In diesem Fall wird die Tabelle mit neuen Hashfunktionen neu aufgebaut.

Pseudocode

Insert(T1,T2,x):
    // key[x] schon in Hashtabelle?
    if T1[h1(key[x])]=NIL or key[T1[h1(key[x])]]=key[x] then
        T1[h1(key[x])]x; return
    if T2[h2(key[x])]=NIL or key[T2[h2(key[x])]]=key[x] then
        T2[h2(key[x])] x; return
    // nein, dann einfügen
    while true do
        xT1[h1(key[x])] // tausche x mit Pos. in T1
        if x=NIL then return
        xT2[h2(key[x])] // tausche x mit Pos. in T2
        if x=NIL then return

Beispiel

Folgende Hashfunktionen sind gegeben:

kh(k)h'(k)
2091
5064
5394
7596
10019
6716
10569
330
3633
3963
1. Tabelle für h(k)
205053751006710533639
0
110067676767100
2
33336
4
5
6505050505010510510550
7
8
920202020202053535375
10
2. Tabelle für h'(k)
205053751006710533639
03
120202020
2
33639
45353535350505053
5
675757575757567
7
8
9100100100100105
10

Zyklus

Möchte man nun das Element 6 einfügen, dann gerät man in einen Zyklus. In der letzten Zeile der Tabelle findet sich die gleiche Ausgangssituation wie zu Beginn wieder.

betrachteter SchlüsselTabelle 1Tabelle 2
alter Wertneuer Wertalter Wertneuer Wert
65065350
5375536775
6710067105100
105610536
33633936
3910539100105
100671007567
7553755053
5039503639
3633663
65065350

Einzelnachweise

  1. Rasmus Pagh, Flemming Friche Rodler: Cuckoo Hashing. 2001 (Online [PDF; 242 kB; abgerufen am 16. Oktober 2021]).