Funktionsweise einer Hashfunktion

Status
Nicht offen für weitere Antworten.

Fenixx

Aktives Mitglied
Guten Abend,

ich habe eine Verständnisfrage zur Funktionsweise einer Hashfunktion.

Angenommen es muss eine eigene Hashtafel implementiert werden, die folgendes leisten muss:
-void put(int value) nimmt value in der Hashtafel auf,
-boolean contains (int value) prüft, ob value in der Hashtafel abgelegt ist,
-void remove (int value) löscht value aus der Hashtafel, falls value dort vorhanden ist,
-boolean isEmpty() prüft, ob die Hashtafel leer ist,
-int load() liefert die Anzahl der belegten Einträge im Feld der Hash-Tafel,
-int size() liefert die Größe des Feldes der Hashtafel,
-void rehash() verdoppelt das Feld der Hashtafel auf 2*size(). rehash() wird ausgeführt, wenn die Anzahl der belegten Elemente in einer Hashtafel mehr als 75% der verfügbaren Elemente des Feldes beträgt.
-Liste allKeys() liefert eine ungeordnete Liste aller in der Hashtafel abgelegten Werte.

Die Hashfunktion h(x) sei gegeben durch:
h(x)=x mod size()
Dabei soll eine Lineare Liste verwendet werden, falls der berechnete Key einer Hashfunktion doppelt vorkommt.

Wird der Key durch die Hashfunktion berechnet?

Das Array von Linearen Listen ist mit der Größe 7 initialisiert.

Nun meine Frage: Ich habe möchte nun 6 und 13 einfügen. Durch die Hashfunktion werden 6 und 13 in die gleiche Klasse eingeteilt, nämlich 6.
In der linearen Liste an der Position [5] gibt es nun 2 Elemente: 6 und 13.
Nun habe ich ja bei einer HashTable immer Key/Value-Paare. Da 6 und 13 aber den gleichen Key haben (6). Dann ist doch die Eindeutigkeit nicht mehr gegeben, oder sehe ich da etwas falsch (was sehr wahrscheinlich sein müsste).
 

tfa

Top Contributor
Eindeutigkeit muss auf jeden Fall gegeben sein. Kollisionen müssen behandelt werden. Such mal nach "geschlossenem Hashing" und "offenem Hashing".
 

Fenixx

Aktives Mitglied
Die Aufgabe ist von einem Übungsblatt.
Um solch eine Kollision zu vermeiden könnte man ja folgende Hashfunktion nehmen:

h_i(x): (h(x)+i) mod size()

So wird bei belegtem Platz der nächste genommen, ist dieser belegt, desssen nächste usw.

Das Konzept ist mir bewusst. Aber ist die Lineare Liste an der Stelle i im Array nicht dafür da, um solche Kollisionen zu vermeiden? Schließlich habe ich ja dann bei gleichem Schlüssel mehrere Elemente in meiner Liste
Oder wofür ist sie sonst da?
Das leuchtet mir noch nicht so ganz ein.
 
S

SlaterB

Gast
zum Vermeiden ist die Hashfunktion, die Liste ist zum Umgehen mit den unvermeidlichen Kollisionen,
eben dadurch, die mehreren Elemente (+Keys) pro Hashwert abzulegen
 

Fenixx

Aktives Mitglied
Wie definierst du vermeidlich und unvermeidlich?
h(x)=x mod size()
Es ist mir nicht bewusst, was hier vermieden werden soll.
Ist nicht der Hashwert in diesem Fall nicht auch gleichzeitig der Key?
 
S

SlaterB

Gast
der Key ist x,
wenn alle x auf h(x) 1 abgebildet werden, dann vermeidet die Hashfunktion gar nicht,
mit x mod size() verhindert die Hashfunktion einiges,
nicht aber den von dir angesprochen Konflikt bei x = 6 und 13 (komische Beispiel, aber ist ja egal)

solche Konflikte lassen sich nicht ganz vermeiden, daher gibt es eine Liste,
in welcher die Paare 6+zugehöriges Objekt sowie 13+zugehöriges Objekt gespeichert sind,

sucht man nun nach Key 6, liefert die Hashfunktion die Liste mit beiden Ablagen, deren Keys muss man noch manuell genauer vergleichen,
ist 13 == oder equal 6? nö nicht so,
ist 6 == oder equal 6? yippie, Key + zugehöriges Objekt zum Suchkey 6 gefunden

selbst wenn die Liste nur ein Element enthalten sollte muss es nicht unbedingt das richtige sein,
gleicher Hashwert bedeutet nicht gleicher Key, sondern nur eine Grobaussortierung aller anderen,
man muss immer mit equals noch den Key genau abgleichen
 
Zuletzt bearbeitet von einem Moderator:

Fenixx

Aktives Mitglied
Wenn ich es richtig versteh:

Die Keys sind 6 und 13. Die Position der Abspeicherung erfolgt durch die Berechnung des Hashcodes durch die Hashfunktion. 6 und 13 haben dann denselben Hashcode?

Aber was sind dann die Values in dem oberen Beispiel?
-void put(int value) nimmt value in der Hashtafel auf (Ich kenne es zugegebenermaßen nur mit put(Key, Value)).

Was sind dann die Values? Doch auch 6 und 13.

Könntest du vielleicht nochmal sauber definieren was was ist? ;-). Ich bin da etwas verwirrt^^.
Vielleicht so: Key/Value/Hashcode

Dann wirds sofort ganz eindeutig.
Vielen Dank

Edit: Sry ich hab dein Edit erst nach dem Post gesehen.
 
Zuletzt bearbeitet:
S

SlaterB

Gast
in einer normalen HashMap lautet die Methode
put(key,value)
insofern kann ich nicht sagen, was bei put(value) passieren soll,

ich vermute, dass es gar keine Values gibt, sondern nur Keys, denn es gibt die Methode
> Liste allKeys() liefert eine ungeordnete Liste aller in der Hashtafel abgelegten Werte.
die Keys mit Werten = Values gleichsetzt ;)

das ganze wäre also in Java-Mitteln ausgedrückt eher ein HashSet statt einer Map
 

Fenixx

Aktives Mitglied
Alles klar;-).
Eine Frage noch. Du meintest ja folgendes:

sucht man nun nach Key 6, liefert die Hashfunktion die Liste mit beiden Ablagen, deren Keys muss man noch manuell genauer vergleichen,
ist 13 == oder equal 6? nö nicht so,
ist 6 == oder equal 6? yippie, Key + zugehöriges Objekt zum Suchkey 6 gefunden

Das heißt doch, dass die Liste die eigentlichen Key/Value-Paare beinhaltet oder?
 
S

SlaterB

Gast
wie gesagt
daher gibt es eine Liste,
in welcher die PAARE 6+zugehöriges Objekt sowie 13+zugehöriges Objekt gespeichert sind,
nach dem Interface des ersten Postings, welches ich damals noch nicht so wirklich bedacht habe,
scheint es aber eher so als wenn nur der Key selber, also die 6 und die 13 gespeichert wird,

ist ja relativ gleich, zentral ist sowieso die Suche nach dem Key selber, ob der exakt so vorhanden ist,

ob man dann den Key zurückgibt oder löscht, nur einen boolean zurückgibt ob vorhanden (contains) oder ein zusätzlich gespeichertes Objekt, wie in einer Map üblich, sind fast schon Randdetails
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
T ObjectInput/OutputStream Fragen zur Funktionsweise Java Basics - Anfänger-Themen 3
S 2 Programmfragmente Funktionsweise Java Basics - Anfänger-Themen 9
S Vererbung Funktionsweise Code zur Vererbung Java Basics - Anfänger-Themen 1
T Erste Schritte Funktionsweise Potenzen in Java Java Basics - Anfänger-Themen 3
P Funktionsweise von ArrayList<E>.set(...) Java Basics - Anfänger-Themen 2
B Funktionsweise Iterator unklar Java Basics - Anfänger-Themen 7
C Methoden Ausgabe aller Attribute einer Instanz ohne einzelne Methode Java Basics - Anfänger-Themen 3
krgewb remove beim Iterieren einer HashMap Java Basics - Anfänger-Themen 3
D wie kann ich gcc aus einer .java datei heraus aufrufen? Java Basics - Anfänger-Themen 2
F http post einer Webseite nachahmen Java Basics - Anfänger-Themen 3
C Abbruch einer Schleife mit break, meine Übung funktioniert nicht richtig Java Basics - Anfänger-Themen 4
G JTable bei aktivieren einer Zelle soll Text selektiert werden. Java Basics - Anfänger-Themen 24
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
D 2 ArrayListen gleich sortieren bzw. eine Liste anhand einer anderen Sortieren Java Basics - Anfänger-Themen 6
ixChronos Letzten 4 Ziffern einer großen Zahl ausgeben Java Basics - Anfänger-Themen 3
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
Shadowrunner Variablen Gibt es eine Möglichkeit die Ziffern/Stellen einer Zahl fest zu legen? Java Basics - Anfänger-Themen 3
D remove Object von einer Liste von Obejcts Java Basics - Anfänger-Themen 3
FunkyPhil94 Wert in einer Lambda Funktion erhöhen Java Basics - Anfänger-Themen 3
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
B Kommunikation mit Seriellen Schnittstellen + Integration einer lib Java Basics - Anfänger-Themen 1
A Daten aus einer HashMap aus einer DB speichern und mit neuen Werten vergleichen Java Basics - Anfänger-Themen 8
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
D Länge einer Liste aufrufen. Java Basics - Anfänger-Themen 19
J Klassen Instanzen einer Klasse in einer anderen unabhängigen Klasse nutzen Java Basics - Anfänger-Themen 4
B Alle Strings bis zu einer Maimallänge aufzählen, die Bedingung erfüllen Java Basics - Anfänger-Themen 13
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
Soranix Erste Schritte Struktur als Anfänger // Von einer Klasse auf ein Objekt einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 6
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
T Fibonacci mit einer Hilfsmethode berechnen Java Basics - Anfänger-Themen 10
S Hilfe zu einer Aufgabe Java Basics - Anfänger-Themen 5
M Radius von einer ellipse bestimmen Java Basics - Anfänger-Themen 7
Say Fehlenden Code finden in einer while-Schleife? Java Basics - Anfänger-Themen 11
M Zufallszahl generieren mit einer linken und rechten Grenze Java Basics - Anfänger-Themen 3
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
G Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
S Best Practice Fragen zu Projektstruktur einer Datenbank-Abfrage-App (MVC) Java Basics - Anfänger-Themen 13
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
nelsonmandela Problem bei Ausgabe einer Switch - Case Funktion Java Basics - Anfänger-Themen 5
S Textausgabe in einer For-Schleife Java Basics - Anfänger-Themen 12
M Spezifischen Wert einer Zeile aus .txt Datei entnehmen Java Basics - Anfänger-Themen 15
B Popups mit Klicksabfangen zumAusfüllen einer .ods Datei Java Basics - Anfänger-Themen 0
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
E Suchfunktion in einer Liste Java Basics - Anfänger-Themen 39
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
FireHorses Einen Command erst nach einer Chateingabe aktivieren Java Basics - Anfänger-Themen 1
frager2345 Singleton-Muster Java ->Nur eine Instanz einer Klasse erzeugen können Java Basics - Anfänger-Themen 45
F wie kann ich die Position des letzten Vokals innerhalb einer Zeichenkette ermitteln? Java Basics - Anfänger-Themen 5
H Kapselung protected aber in einer Kindklasse nicht zugänglich Java Basics - Anfänger-Themen 5
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
B Den Dateipfad einer Java Datei durch Code in Selbiger finden? Java Basics - Anfänger-Themen 10
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
stormyark Fehler beim überschreiben einer Variable Java Basics - Anfänger-Themen 1
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
Saiko Zeilen einer Datei einlesen Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
G zwei Instanzen einer Klasse Java Basics - Anfänger-Themen 29
sserio Prüfziffer einer ISBN Nummer herrausfinden. Java Basics - Anfänger-Themen 14
J Benennung einer mir unbekannten Java - Ausdrucksweise Java Basics - Anfänger-Themen 5
LFB In einer For-Schleife alles in einer Zeile ausgeben Java Basics - Anfänger-Themen 14
sserio Wie kann man nach einer Klasse fragen? Java Basics - Anfänger-Themen 12
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Wie gebe ich den Pfad zu einer Datei an, die in einem Ordner in Eclipse ist? Java Basics - Anfänger-Themen 1
M Variable in einer Schleife initialisieren Java Basics - Anfänger-Themen 46
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
J int innerhalb einer Datei ändern Java Basics - Anfänger-Themen 1
D Hilfe bei einer Aufgabe mit for-Schleife Java Basics - Anfänger-Themen 6
Neuling47 Ich zerbreche mit den kopf an einer Aufgabe Java Basics - Anfänger-Themen 61
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
J Zelleninhalt einer Jtable löschen Java Basics - Anfänger-Themen 2
Robert_Klaus Hamster java Simulation Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
stormyark 4 Bit in einer for-schleife funktioniert nicht Java Basics - Anfänger-Themen 3
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
A Ein Array bearbeiten und in einer anderen Methode nutzen Java Basics - Anfänger-Themen 6
A Ergebnis einer Methode bei einer anderen verwenden Java Basics - Anfänger-Themen 13
I Interface von einer EJB Klasse, um Code zu reduzieren Java Basics - Anfänger-Themen 1
M Interface als Parameter einer Klasse Java Basics - Anfänger-Themen 8
I Liste von Infos von einer eigenen Annotation in Liste speichern Java Basics - Anfänger-Themen 0
M Wie kann ich den Index i von einer LinkedList überprüfen? Java Basics - Anfänger-Themen 36
M Wie kann die Implementation einer Methode den Wert eines Attributs vermindern? Java Basics - Anfänger-Themen 3
M Wie verknüpfe ich eine Bedingung mit einer Methode ohne if-Verzweigung & Bedingungsoperator? Java Basics - Anfänger-Themen 2
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
javapingu Jeglichen Inhalt einer Textdatei nach Zeile n löschen Java Basics - Anfänger-Themen 8
D mehrere Berechnungen in einer Methode Java Basics - Anfänger-Themen 9
P Iterieren mit einer Foreach in Lambdaschreibweise und Counter. Java Basics - Anfänger-Themen 1
M Methoden Wert einer Variable geht verloren? Java Basics - Anfänger-Themen 6
W Wie ziehe ich von einer bestimmten Zahl, Zahlen ab, bis mein Ergebnis null beträgt? Java Basics - Anfänger-Themen 10
X Was ist der Unterschied zwischen materialisierten und nichtmaterialisierten Attributen einer Klasse? Java Basics - Anfänger-Themen 1
U Wie ein Attribut von einer Klassenmethode in der Klasse speichern= Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben