Deutsch
Experimente

Stringdistanzen numerisch ermitteln (Geplanter FastSearch-Algorithmus)

 

p.specht

Es gibt gefinkelte Such- und Sortieralgorithmen, die neben simplen Suchvektoren auch die Inhalte der Datenfelder selbst berücksichtigen. Wenn ein Mensch z.B. ein Telefonbuch aufschlägt um ein Wort mit "Z..." zu suchen, wird er vermutlich nicht vorne, nicht mittig, sonder eher weit hinten zu suchen beginnen. Algorithmen wie z.B. "FastSearch" treffen in XProfan aber auf zwei Probleme: Anders als in C++ oder in Assembler können Strings nicht rasch und einfach als Zahlenwerte ausgelesen werden. Die zweite Schwierigkeit stellt dabei auch das in PCs verwendete "verkehrte" INTEL-Zahlenformat dar. Mag sein, daß es da Tricks gibt, die mir noch nicht bekannt sind. In Vorbereitung für den Fastsearch-Algorithmus (für vorsortierte, gleichverteilte Dateien) habe ich mir einstweilen folgendermaßen beholfen:
WindowTitle "Distanzen zwischen String-Anfängen (erste 4 Zeichen) ermitteln."
'(DW) Demoware/Testware 2015-01 by P.Specht, Wien (AT); Ohne jede Gewähr!
WindowStyle 24:Window 0,0-%maxx,%maxy-40:randomize
var n&=40
declare stra$[n&-1],tmp$,i&,j&,vec&,su$,tmp&
print "\n Ihr Basiswort (z.B. 1-4 Zeichen ihres Vornamens) bitte: ";
input su$:su$=lower$(su$)
print "\n Generierung von ";n&;" alphabetischen Zufalls-Strings der Länge [1..8], ... ";

whileloop 0,n&-1:tmp$="":whileloop 1+rnd(6):tmp$=tmp$+chr$(97+rnd(26))

    endwhile :stra$[&Loop]=tmp$:endwhile
    Print "\n die zwecks Überprüfbarkeit nun nach Stringdistanzwerten sortiert werden."

    whileloop 0,n&-1:i&=&Loop

        whileloop 0,n&-1:j&=&Loop

            if ASC4(stra$[i&]) < ASC4(stra$[j&])' if stra$[i&] < stra$[j&] 'Sort-Test

                tmp$=stra$[i&]:stra$[i&]=stra$[j&]:stra$[j&]=tmp$

            endif

        endwhile

    endwhile

    ' Ausgabe:

    whileloop 0,n&-1:j&=&Loop

        print tab(3);chr$(34)+stra$[j&]+chr$(34);\
        tab(14);" ist von ";chr$(34)+su$+chr$(34);tab(35);str$(int( ASC4(stra$[j&])-ASC4(su$)));\
        tab(50);" mögliche 4-Ketten entfernt."

    endwhile

    waitinput
    end

    proc ASC4 :parameters x$

        'Stringwert der ersten vier ASCII-Zeichen ermittlen (passen in eine Long-Variable)
        declare x&',xl&:xl&=if(len(x$)<4,len(x$),4)

        select if(len(x$)<4,len(x$),4)

            caseof 0:x&=0

            caseof 1:x&=byte(addr(x$),0)<<23

            caseof 2:x&=byte(addr(x$),1)<<15 | byte(addr(x$),0)<<23

            caseof 3:x&=byte(addr(x$),2)<<7 | byte(addr(x$),1)<<15 | byte(addr(x$),0)<<23

            caseof 4:x&=byte(addr(x$),3)>>1 | byte(addr(x$),2)<<7 | byte(addr(x$),1)<<15 | byte(addr(x$),0)<<23

            otherwise :print "select error"
            endselect :return x&

        endproc

 
XProfan 11
Computer: Gerät, daß es in Mikrosekunden erlaubt, 50.000 Fehler zu machen, zB 'daß' statt 'das'...
12.05.2021  
 



Zum Experiment


Thementitel, max. 100 Zeichen.
 

Systemprofile:

Kein Systemprofil angelegt. [anlegen]

XProfan:

 Beitrag  Schrift  Smilies  ▼ 

Bitte anmelden um einen Beitrag zu verfassen.
 

Themenoptionen

674 Betrachtungen

Unbenanntvor 0 min.
Ernst21.07.2021
Uwe ''Pascal'' Niemeier13.06.2021
R.Schneider28.05.2021
Michael W.28.05.2021
Mehr...

Themeninformationen

Dieses Thema hat 1 Teilnehmer:

p.specht (1x)


Admins  |  AGB  |  Anwendungen  |  Autoren  |  Chat  |  Datenschutz  |  Download  |  Eingangshalle  |  Hilfe  |  Händlerportal  |  Impressum  |  Mart  |  Schnittstellen  |  SDK  |  Services  |  Spiele  |  Suche  |  Support

Ein Projekt aller XProfaner, die es gibt!


Mein XProfan
Private Nachrichten
Eigenes Ablageforum
Themen-Merkliste
Eigene Beiträge
Eigene Themen
Zwischenablage
Abmelden
 Deutsch English Français Español Italia
Übersetzungen

Datenschutz


Wir verwenden Cookies nur als Session-Cookies wegen der technischen Notwendigkeit und bei uns gibt es keine Cookies von Drittanbietern.

Wenn du hier auf unsere Webseite klickst oder navigierst, stimmst du unserer Erfassung von Informationen in unseren Cookies auf XProfan.Net zu.

Weitere Informationen zu unseren Cookies und dazu, wie du die Kontrolle darüber behältst, findest du in unserer nachfolgenden Datenschutzerklärung.


einverstandenDatenschutzerklärung
Ich möchte keinen Cookie