AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Algorithmen um Listen abzugleichen

Ein Thema von freimatz · begonnen am 5. Sep 2024 · letzter Beitrag vom 7. Sep 2024
Antwort Antwort
freimatz

Registriert seit: 20. Mai 2010
1.456 Beiträge
 
Delphi 11 Alexandria
 
#1

Algorithmen um Listen abzugleichen

  Alt 5. Sep 2024, 16:24
Hallo zusammen,
"Algorithmen, Datenstrukturen und Klassendesign" - mir geht hier um Algorithmen. Falls jemand Lust auf Knobeleien hat, freue ich mich auf Anregungen.

Gegeben sei ein ordinaler Typ. Das wäre konkret ein Aufzählungstyp, ich nehme hier einfach mal Buchstaben. Die Anzahl ist typischerweise ca. 50.
Zu diesem Typ gibt es Listen. Das kann ein Array, TList oder IList sein. Die Reihenfolge ist aber wichtig.

Gesucht wird (zuerst mal) ein Algorithmus mit dem man prüfen kann ob die Reihenfolge einer Liste stimmt anhand einer anderen Liste. Beispiel:
Referenzliste: (a,d,e,c,b)
Beispiele für Ok-Fälle: (a,c,b), (a,d,e,c,b), (), (c,b)
Beispiele für Ko-Fälle: (a,b,a), (a,a,c)

(Bitte keine "Kanonen" wie TStringList, TMemTable oder ähnlichem )
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.184 Beiträge
 
Delphi 12 Athens
 
#2

AW: Algorithmen um Listen abzugleichen

  Alt 5. Sep 2024, 16:38
Nja, im Grunde mußt du doch nur deine "Liste" von Anfang bis Ende durchlaufen. (z.B. For-Schleife)
Und da prüfst du dann jeweils, ob bei zwei aufeinanderfolgende "Items" die Indize (der ordinale Wert) größer werden, als dessen Vorgänger.
Bei gleich oder kleiner, ist es "nicht OK".
$2B or not $2B

Geändert von himitsu ( 5. Sep 2024 um 16:40 Uhr)
  Mit Zitat antworten Zitat
freimatz

Registriert seit: 20. Mai 2010
1.456 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: Algorithmen um Listen abzugleichen

  Alt 7. Sep 2024, 07:45
Hm, weis nicht ob ich Dich richtig verstehe... Vielleicht liegt es daran dass ich in dem Beispiel keinen Typ angegeben habe. Der wäre z.B. TBla = (a,b,c,d,e,f,g)
Die Referenzliste ist in dem Beispiel: (a,d,e,c,b).
Die ordinalen Werte wären dann: 1,4,5,3,2.
Bei dem Ok-Fall (a,c,b) wäre die dann 1,3,2 - und somit nicht aufsteigend.

Aber man könnte ja vor der Prüfung eines Falles, die Werte umrechnen in die Position wo sie in der Referenzliste sind.
  Mit Zitat antworten Zitat
Benutzerbild von Gausi
Gausi

Registriert seit: 17. Jul 2005
885 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Algorithmen um Listen abzugleichen

  Alt 7. Sep 2024, 08:08
Einfach so runtergeschrieben:
Delphi-Quellcode:
function TestListIsValid(TestListe, ReferenzListe: TSomeList): boolean;
var
  idxR, idxT: Integer;
begin
  idxR := 0;
  idxT := 0;

  // Hauptschleife: Die Testliste durchgehen
  while (idxT <= TestListe.Count - 1) and (idxR <= ReferenzListe.Count - 1) do begin
    // nächste Übereinstimmung in der Referenzliste suchen
    while (TestListe[idxT] <> ReferenzListe[idxR]) and (idxR < ReferenzListe.Count - 1) do
      inc(idxR);

    if TestListe[idxT] = ReferenzListe[idxR] then begin
      // Übereinstimmung gefunden, in beiden Listen eins weiter gehen
      inc(idxT);
      inc(idxR);
    end;
  end;

  // Die Testliste passt, wenn man die Testliste komplett durchlaufen hat.
  Result := idxT = TestListe.Count;
end;
Laufzeit: Linear in der Länge der Listen.
The angels have the phone box.

Geändert von Gausi ( 7. Sep 2024 um 08:20 Uhr)
  Mit Zitat antworten Zitat
Alt 18. Sep 2024, 13:29     Erstellt von fyre1212
Dieser Beitrag wurde von TBx gelöscht. - Grund: Verdacht auf SPAM und den damit verbundenen verschwenderischen Umgang von wertvollen Bits und Bytes
Alt 24. Okt 2024, 15:28     Erstellt von Kinsley
Dieser Beitrag wurde von TBx gelöscht. - Grund: Verdacht auf SPAM und den damit verbundenen verschwenderischen Umgang von wertvollen Bits und Bytes
Alt 9. Dez 2024, 18:27     Erstellt von lovemarieyu4
Dieser Beitrag wurde von Daniel gelöscht. - Grund: Verdacht auf SPAM und den damit verbundenen verschwenderischen Umgang von wertvollen Bits und Bytes
Antwort Antwort


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 04:26 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz