AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Array of tstringlist per quicksort sortieren
Thema durchsuchen
Ansicht
Themen-Optionen

Array of tstringlist per quicksort sortieren

Ein Thema von Jan · begonnen am 13. Feb 2003 · letzter Beitrag vom 15. Feb 2003
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Jan
Jan

Registriert seit: 24. Sep 2002
Ort: Magdeburg
491 Beiträge
 
Delphi 7 Enterprise
 
#1

Array of tstringlist per quicksort sortieren

  Alt 13. Feb 2003, 20:44
Hallo DP,
mein Problem schildert sich wie folgt:
Ich habe ein 2-dimensionales dynamisches array, welches so definiert ist:

Code:
workarray : array of tstringlist;
Und nun will ich anhand eines Kriteriums in den stringlists meinen array (z.B. workarray[i][2]) sortieren, undzwar per quicksort.
Ich sortiere also nicht einfach nur array[i] sondern ich sortiere array[i] anhand von dem was in array[i][2] steht.

Ich habe dazu den Code aus der DP-Code library für quicksort umgeschrieben, und erhalte dies:

Code:
Procedure tform1.QuickSort( l,r : Integer );
var i : Integer;
Begin
  If (r > l) Then
  Begin
    i:= Partition( l, r);
    QuickSort( l, i-1 );
    QuickSort( i+1, r );
  End;
End;

Function tform1.Partition( l,r : Integer ) : Integer;
var i,j : Integer;
    v    : string;
    t    : tstringlist;
Begin
  t:=tstringlist.Create;
  v:= workarray[r][1];
  i:= l-1;
  j:= r;
  Repeat
    Repeat inc( i ); Until (workarray[i][1] >= v);
    Repeat dec( j ); Until (workarray[j][1] <= v);
    t:= workarray[i]; workarray[i]:= workarray[j]; workarray[j]:= t;
  Until (j<=i);

  workarray[j]:= workarray[i]; workarray[i]:= workarray[r]; workarray[r]:= t;
  Result:= i;
  t.free;
End;
Im Moment bekomme ich einen Fehler, der so heisst:

"Listenindex überschreitet das Maximum (1)".

könnte mir vielleicht jemand sagen woher das kommt? Und wenn ich das weiss, koennte mir dann vielleicht auch noch jemand sagen, ob das so, wie ich das da geschrieben habe überhaupt klappen kann?

Gruß
Jan
Jan
Wenn die Sonne der Kultur tief steht, werfen auch kleine Gestalten lange Schatten.
  Mit Zitat antworten Zitat
Benutzerbild von nailor
nailor

Registriert seit: 12. Dez 2002
Ort: Karlsruhe
1.989 Beiträge
 
#2
  Alt 13. Feb 2003, 21:49
Ich bin zu faul nachzuschauen, ob sich der Fehler nicht schon so klären liese, aber es wäre auf jeden Fall nett zu wissen, wo der Fehler GENAU auftritt, und was für eine Stringlist du als Input gibst.
Michael N.
http://nailor.devzero.de/code/sharpmath/testing/ --- Tests, Feedback, Anregungen, ... aller Art sehr willkommen!
::: don't try so hard - it'll happen for a reason :::
  Mit Zitat antworten Zitat
Benutzerbild von Jan
Jan

Registriert seit: 24. Sep 2002
Ort: Magdeburg
491 Beiträge
 
Delphi 7 Enterprise
 
#3
  Alt 13. Feb 2003, 21:53
Hallo Nailor,
also ich habe keine Ahnung wo der Fehler auftritt, weil mir mein Delphi das nur bei jedem 10. Error anzeigt.

Und bezüglich der Eingabe:

workarray : array of tstringlist;

das sind mehrere stringlists, die jeweils 9 einträge haben, und ich will die stringlists anhand dessen, was bei jeder stringlist an einer bestimmten stelle steht sortieren.
Gruß
Jan
Jan
Wenn die Sonne der Kultur tief steht, werfen auch kleine Gestalten lange Schatten.
  Mit Zitat antworten Zitat
Benutzerbild von Jan
Jan

Registriert seit: 24. Sep 2002
Ort: Magdeburg
491 Beiträge
 
Delphi 7 Enterprise
 
#4
  Alt 13. Feb 2003, 21:55
ich muss mich korrigieren,
der fehler tritt hier auf:
Code:
Repeat dec( j ); Until (workarray[j][1] <= v);
komischerweise aber nicht in der zeile direkt da drüber, obwohl die ja eigentlich genau das gleiche nur andersrum macht.

der Fehler heisst jetzt ausserdem noch: "zugriffsverletzung bei der addresse blablabla"

Greetz
Jan
Jan
Wenn die Sonne der Kultur tief steht, werfen auch kleine Gestalten lange Schatten.
  Mit Zitat antworten Zitat
Benutzerbild von nailor
nailor

Registriert seit: 12. Dez 2002
Ort: Karlsruhe
1.989 Beiträge
 
#5
  Alt 13. Feb 2003, 22:01
Willst du eigentlich Strings/eine Stringlist sortieren, oder wirklich einen var workarray: array of TStringList ???
Michael N.
http://nailor.devzero.de/code/sharpmath/testing/ --- Tests, Feedback, Anregungen, ... aller Art sehr willkommen!
::: don't try so hard - it'll happen for a reason :::
  Mit Zitat antworten Zitat
Benutzerbild von Jan
Jan

Registriert seit: 24. Sep 2002
Ort: Magdeburg
491 Beiträge
 
Delphi 7 Enterprise
 
#6
  Alt 13. Feb 2003, 22:07
ich will den array sortieren, der die stringlists beinhaltet.
Jan
Wenn die Sonne der Kultur tief steht, werfen auch kleine Gestalten lange Schatten.
  Mit Zitat antworten Zitat
Benutzerbild von nailor
nailor

Registriert seit: 12. Dez 2002
Ort: Karlsruhe
1.989 Beiträge
 
#7
  Alt 13. Feb 2003, 22:07
wa, mein Beitrag grade war so falsch, dass ich ihn mal lieber weggemacht habe, um nicht Verwirrung zu stiften.

---

neuer, sinvoller Beitrag: und welche Stringlist soll am weitesten nach vorne? Beschreib mal in Worten.
Michael N.
http://nailor.devzero.de/code/sharpmath/testing/ --- Tests, Feedback, Anregungen, ... aller Art sehr willkommen!
::: don't try so hard - it'll happen for a reason :::
  Mit Zitat antworten Zitat
Benutzerbild von Jan
Jan

Registriert seit: 24. Sep 2002
Ort: Magdeburg
491 Beiträge
 
Delphi 7 Enterprise
 
#8
  Alt 14. Feb 2003, 20:57
Hallöchen,
weiss da keiner eine Antwort drauf, oder habt ihr einfach alle keine Lust? :[
brauche da echt Hilfe, weil ohne selbige steige ich da nicht im geringsten durch.
Danke
Jan
Jan
Wenn die Sonne der Kultur tief steht, werfen auch kleine Gestalten lange Schatten.
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#9
  Alt 14. Feb 2003, 21:44
Na, irgendwo stimmt was mit deinen Indizes nicht. Überprüf die noch mal. Geh mal mit F7 durch dein QuickSort durch.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von Jan
Jan

Registriert seit: 24. Sep 2002
Ort: Magdeburg
491 Beiträge
 
Delphi 7 Enterprise
 
#10
  Alt 14. Feb 2003, 22:40
so, ich bin jetzt die ganzen for-schleifen mal mit f7 durchgegangen und er bleibt immernoch bei:

Code:
Repeat dec( j ); Until (workarray[j][1] <= v);
stehen.
mit einer access violation.
Ich glaube auch nicht´, dass da ein echter Code-fehler drin ist, schliesslich kann ich das Programm ja auch kompilieren und alles, aber ich würde gerne wissen, ob man das so, wie ich das gecode habe überhaupt machen kann, dazu muesste mal jemand den code lesen wenn er zeit hat, und mir dann seine ergebnisse mitteilen. Wäre echt net das.
Gruß
Jan
Jan
Wenn die Sonne der Kultur tief steht, werfen auch kleine Gestalten lange Schatten.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 21:41 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