AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Hashen: Integerüberläufe, Hornerschema in Delphi
Thema durchsuchen
Ansicht
Themen-Optionen

Hashen: Integerüberläufe, Hornerschema in Delphi

Ein Thema von skizz · begonnen am 14. Sep 2009 · letzter Beitrag vom 14. Sep 2009
 
skizz

Registriert seit: 14. Sep 2009
2 Beiträge
 
#1

Hashen: Integerüberläufe, Hornerschema in Delphi

  Alt 14. Sep 2009, 17:35
Ich mache im Augenblick ein Projekt zum Thema:
Hashen von Strings, mithilfe der Divisionsrestmethode:
Strings wandel ich um durch deren ASCII Wert mal der Basis 128.
Problem: Die Zahlen werden recht groß.

Bei der Divisionsrestmethode muss ich diese nun durch m (in der Regel Tabellengröße) teilen.

Dabei gibt es nun ein Hornerschema, welches integer Überläufe verhindert.

Theorie:

h(HAUS) = ( ord(H)*128³ + ord(A)*128² + ord(U)*128 + ord(S)) mod m
H(HAUS)= [ 72*128³ + 65*128² + 85* 128 + 83 ] mod m
= [ ((72*128 + 65)*128 + 85)*128 + 83 ] mod m
= [ ((72 mod m *128 + 65) mod m *128 + 85) mod m *128 + 83 ] mod m


Praxis: Problem dabei ist wie ich wiederholt das mod m hinein bekomme.
(Siehe Theorie oben: Fettgedrucktes.) Das ganze soll immer noch mit einer variablen Länge des Strings möglich sein.

Wikipedia meint im Pseudocode:

h = s[1] mod m
for i in 2...l:
h = (h * 128 + s[i]) mod m



Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var s : string;
i,d,x,m,laenge,h,ergebnis,c : integer;
pos : integer = 1;

begin

   {Divisionsrestmethode bei Strings

  s speichert den string, i,j zählervariabeln
   power(basis, exponent) = b^exponent, benötigt uses math}


   m := strtoint(edit2.text); //auslesen des Teilers aus einem Editfeld
   s := edit1.Text; // auslesen des strings
   laenge := length(s);
   c:= 1;
 
 //umrechnung von string in zahlen zur basis b h := ord(s[j])*round(power(128,(laenge-c)));
  
for i:= 0 to laenge-1 do
   begin
   h := (ord(s[pos])*round(power(128,(laenge-c))) mod m) ;

{   x := (laenge+1-c); das ist die Anzahl der "mod m"'s die ich im Prinzip bei dem obrigen mod m benötige }

   //showmessage(s[j] + inttostr(ord(s[j]))); //prüfen der Ordinaten:
   ergebnis:= ergebnis+h; //summieren der Hashwerte der Einzelnen Ordinaten
   pos:= pos+1;
   c:= c+1;
   end;

 memo1.Text := inttostr(ergebnis); //anzeigen des Ergebnises

   //reset der Variabeln
   ergebnis:= 0;
   c:= 1;
   pos:= 1;
end;

Eine Modifikation meines Codes oder eine Übersetzung des Pseudocodes(sofern er funktioniert) würden mir doch weiter helfen.

MfG
  Mit Zitat antworten Zitat
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 05:25 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz