![]() |
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:
Delphi-Quellcode:
Kann mir jemand sagen, wo der Fehler ist?
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; |
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 |
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; |
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 |
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