Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Sortierverfahren in einer txt-Datei (https://www.delphipraxis.net/60409-sortierverfahren-einer-txt-datei.html)

boozzz 6. Jan 2006 13:18


Sortierverfahren in einer txt-Datei
 
Hi,
beim sortieren von Werten, die aus einer Textdatei gelesen werden, kommt bei mir immer folgende Fehlermeldung (Fehlermeldung erscheint immer beim Klick auf den Button "bestenlistebutton"):
Zitat:

Im Projekt Project1.exe ist eine Exception der Klasse EStackOverflow aufgetreten. Meldung: ‚Stack-Überlauf’. Prozess wurde angehalten. Mit Einzelne Anweisung oder Start fortsetzen.
Der folgende Quellcode-Ausschnitt liest aus jeder zweiten Zeile der Textdatei "memory" einen Integer-Wert und sortiert alle Werte der Größe nach.

Delphi-Quellcode:
procedure TForm1.bestenlistebuttonClick(Sender: TObject);
var ende,zwischenspeicher,lauefer,x,y:integer;
    platz: array[1..10000] of integer;
begin
  bestenliste.Show;

  highscore:=TStringList.Create;
  if FileExists ('memory.txt') then
    highscore.LoadFromFile('memory.txt');
     
  ende:=highscore.Count;

  zwischenspeicher:=0;
  platz[1]:=StrToInt(highscore[0]);

  for x:=1 to 10 do
  begin
    lauefer:=0;
    repeat
      zwischenspeicher:=StrToInt(highscore[lauefer]);

      if zwischenspeicher>platz[x] then
      begin
        platz[x+9]:=platz[x+8];
        platz[x+8]:=platz[x+7];
        platz[x+7]:=platz[x+6];
        platz[x+6]:=platz[x+5];
        platz[x+5]:=platz[x+4];
        platz[x+4]:=platz[x+3];
        platz[x+3]:=platz[x+2];
        platz[x+2]:=platz[x+1];
        platz[x+1]:=platz[x];
        platz[x]:=zwischenspeicher;
      end;

      lauefer:=lauefer+2;                             //Es soll nur jede zweite Zeile der Textdatei verglichen werden
    until lauefer=ende;
  end;

  bestenliste.Label1.Caption:=IntToStr(platz[1]);
  bestenliste.Label2.Caption:=IntToStr(platz[2]);
  bestenliste.Label3.Caption:=IntToStr(platz[3]);
  bestenliste.Label4.Caption:=IntToStr(platz[4]);
  bestenliste.Label5.Caption:=IntToStr(platz[5]);
  bestenliste.Label6.Caption:=IntToStr(platz[6]);
  bestenliste.Label7.Caption:=IntToStr(platz[7]);
  bestenliste.Label8.Caption:=IntToStr(platz[8]);
  bestenliste.Label9.Caption:=IntToStr(platz[9]);
  bestenliste.Label10.Caption:=IntToStr(platz[10]);

  highscore.Free;
end;
Kann mir jemand sagen, wo der Fehler ist?

marabu 6. Jan 2006 14:22

Re: Sortierverfahren in einer txt-Datei
 
Hallo.

Der Stack-Überlauf erfolgt wahrscheinlich durch mehrfachen Wiedereintritt in diese Routine und wird woanders verursacht. Vielleicht musst du mal prüfen, ob du das im Ereignis OnShow() deines Formulars BestenListe verbrichst.

Ansonsten würde ich dir empfehlen, die HighScores immer sortiert zu halten - du sparst dir dann das eigentlich überflüssige Sortieren. Du musst auch nicht zweizeilig speichern, die StringList kommt sehr gut mit Einträgen der Form BOOZZ=42000 zurecht.

Die Bereitstellung eines statischen array Platz im Unfang von 40.000 Byte halte ich für überdimensioniert, wenn doch nur 0 bis maximal 10 Einträge existieren.

Ein Zugriff auf highscore[0] findet bei dir auch dann statt, wenn noch keine Bestenliste gespeichert wurde - und führt dann zu einem Indexfehler.

Freundliche Grüße vom marabu

boozzz 6. Jan 2006 14:45

Re: Sortierverfahren in einer txt-Datei
 
Das Problem mit dem Stack-Überlauf wäre gelöst. Das Problem war, dass der Inhalt der Variablen "ende" ungerade war. Daraus ergab sich eine Endlosschleife.

Jetzt hab ich aber ein neues Problem. Es soll nun von unten nach oben sortiert werden (wertniedrigste Zahl zuerst).

Problem: In der Bestenliste wird nur die niedrigste Zahl gespeichert. Das heißt: platz[1], platz[2], platz[3],... haben alle den selben (niedrigsten) Wert.
Delphi-Quellcode:
procedure TForm1.bestenlistebuttonClick(Sender: TObject);
var ende,zwischenspeicher,lauefer,x:integer;
    platz: array[1..10000] of integer;
begin
  bestenliste.Show;

  highscore:=TStringList.Create;
  if FileExists ('memory.txt') then
    highscore.LoadFromFile('memory.txt');

  ende:=highscore.Count;

  lauefer:=0;

  for x:=1 to 10 do
  begin
    platz[x]:=StrToInt(highscore[lauefer]);
    lauefer:=lauefer+2;
  end;

  for x:=1 to 10 do
  begin
    lauefer:=2;
    repeat
      zwischenspeicher:=StrToInt(highscore[lauefer]);
      if zwischenspeicher<platz[x] then
      begin
        platz[x+9]:=platz[x+8];
        platz[x+8]:=platz[x+7];
        platz[x+7]:=platz[x+6];
        platz[x+6]:=platz[x+5];
        platz[x+5]:=platz[x+4];
        platz[x+4]:=platz[x+3];
        platz[x+3]:=platz[x+2];
        platz[x+2]:=platz[x+1];
        platz[x+1]:=platz[x];
        platz[x]:=zwischenspeicher;
      end else
      if zwischenspeicher<platz[x+1] then
      begin
        platz[x+9]:=platz[x+8];
        platz[x+8]:=platz[x+7];
        platz[x+7]:=platz[x+6];
        platz[x+6]:=platz[x+5];
        platz[x+5]:=platz[x+4];
        platz[x+4]:=platz[x+3];
        platz[x+3]:=platz[x+2];
        platz[x+2]:=platz[x+1];
        platz[x+1]:=zwischenspeicher;
      end else
      if zwischenspeicher<platz[x+2] then
      begin
        platz[x+9]:=platz[x+8];
        platz[x+8]:=platz[x+7];
        platz[x+7]:=platz[x+6];
        platz[x+6]:=platz[x+5];
        platz[x+5]:=platz[x+4];
        platz[x+4]:=platz[x+3];
        platz[x+3]:=platz[x+2];
        platz[x+2]:=zwischenspeicher;
      end else
      if zwischenspeicher<platz[x+3] then
      begin
        platz[x+9]:=platz[x+8];
        platz[x+8]:=platz[x+7];
        platz[x+7]:=platz[x+6];
        platz[x+6]:=platz[x+5];
        platz[x+5]:=platz[x+4];
        platz[x+4]:=platz[x+3];
        platz[x+3]:=zwischenspeicher;
      end else
      if zwischenspeicher<platz[x+4] then
      begin
        platz[x+9]:=platz[x+8];
        platz[x+8]:=platz[x+7];
        platz[x+7]:=platz[x+6];
        platz[x+6]:=platz[x+5];
        platz[x+5]:=platz[x+4];
        platz[x+4]:=zwischenspeicher;
      end else
      if zwischenspeicher<platz[x+5] then
      begin
        platz[x+9]:=platz[x+8];
        platz[x+8]:=platz[x+7];
        platz[x+7]:=platz[x+6];
        platz[x+6]:=platz[x+5];
        platz[x+5]:=zwischenspeicher;
      end else
      if zwischenspeicher<platz[x+6] then
      begin
        platz[x+9]:=platz[x+8];
        platz[x+8]:=platz[x+7];
        platz[x+7]:=platz[x+6];
        platz[x+6]:=zwischenspeicher;
      end else
      if zwischenspeicher<platz[x+7] then
      begin
        platz[x+9]:=platz[x+8];
        platz[x+8]:=platz[x+7];
        platz[x+7]:=zwischenspeicher;
      end else
      if zwischenspeicher<platz[x+8] then
      begin
        platz[x+9]:=platz[x+8];
        platz[x+8]:=zwischenspeicher;
      end else
      if zwischenspeicher<platz[x+9] then
      begin
        platz[x+9]:=zwischenspeicher;
      end;

      lauefer:=lauefer+2;
    until (lauefer=ende) or (lauefer+1=ende);
  end;
  Form1.Edit1.Text:=IntToStr(zwischenspeicher);
  bestenliste.Label1.Caption:=IntToStr(platz[1]);
  bestenliste.Label2.Caption:=IntToStr(platz[2]);
  bestenliste.Label3.Caption:=IntToStr(platz[3]);
  bestenliste.Label4.Caption:=IntToStr(platz[4]);
  bestenliste.Label5.Caption:=IntToStr(platz[5]);
  bestenliste.Label6.Caption:=IntToStr(platz[6]);
  bestenliste.Label7.Caption:=IntToStr(platz[7]);
  bestenliste.Label8.Caption:=IntToStr(platz[8]);
  bestenliste.Label9.Caption:=IntToStr(platz[9]);
  bestenliste.Label10.Caption:=IntToStr(platz[10]);

  highscore.Free;
end;

marabu 6. Jan 2006 16:46

Re: Sortierverfahren in einer txt-Datei
 
Liste der Anhänge anzeigen (Anzahl: 1)
Dein Sortierprozess sieht aus als ob man ihn noch etwas verbessern könnte. Vielleicht magst du dir ja die angehängte Demo mal anschauen. Darin kannst du sehen wie eine HighScore-Liste in einem ValueListEditor angezeigt und sortiert wird.

marabu

boozzz 6. Jan 2006 18:06

Re: Sortierverfahren in einer txt-Datei
 
Danke, habs schon alleine hinbekommen:

Delphi-Quellcode:
procedure TForm1.bestenlistebuttonClick(Sender: TObject);
var ende,zwischenspeicher,lauefer,lauefer2,x,y,wertespeicher,wabbel:integer;
    personenspeicher: string;
    platz: array[1..100] of integer;
    person: array[1..100] of string;
begin
  bestenliste.Show;

  highscore:=TStringList.Create;
  if FileExists ('memory.txt') then
  begin
    highscore.LoadFromFile('memory.txt');
    ende:=highscore.Count;

    lauefer:=0;
    lauefer2:=1;

    for x:=1 to 10 do
    begin
      if (highscore.Count/2>=x) then
      begin
        platz[x]:=StrToInt(highscore[lauefer]);
        lauefer:=lauefer+2;
        person[x]:=highscore[lauefer2];
        lauefer2:=lauefer2+2;
      end;
    end;

    for y:=1 to 10 do
    begin
      for x:=1 to 10 do
      begin
        if (highscore.Count/2>=x) then
        begin
          if platz[x+1]<platz[x] then
          begin
            wertespeicher:=platz[x];
            personenspeicher:=person[x];
            platz[x]:=platz[x+1];
            person[x]:=person[x+1];
            platz[x+1]:=wertespeicher;
            person[x+1]:=personenspeicher;
          end;
        end;
      end;
    end;

    bestenliste.Label1.Caption:=IntToStr(platz[2]);
    bestenliste.Label2.Caption:=IntToStr(platz[3]);
    bestenliste.Label3.Caption:=IntToStr(platz[4]);
    bestenliste.Label4.Caption:=IntToStr(platz[5]);
    bestenliste.Label5.Caption:=IntToStr(platz[6]);
    bestenliste.Label6.Caption:=IntToStr(platz[7]);
    bestenliste.Label7.Caption:=IntToStr(platz[8]);
    bestenliste.Label8.Caption:=IntToStr(platz[9]);
    bestenliste.Label9.Caption:=IntToStr(platz[10]);

    bestenliste.Label39.Caption:=person[2];
    bestenliste.Label38.Caption:=person[3];
    bestenliste.Label37.Caption:=person[4];
    bestenliste.Label36.Caption:=person[5];
    bestenliste.Label35.Caption:=person[6];
    bestenliste.Label34.Caption:=person[7];
    bestenliste.Label33.Caption:=person[8];
    bestenliste.Label32.Caption:=person[9];
    bestenliste.Label31.Caption:=person[10];

    highscore.Free;
  end;
end;


Alle Zeitangaben in WEZ +1. Es ist jetzt 03:01 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