AGB  ·  Datenschutz  ·  Impressum  







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

Stringgrid sortieren

Ein Thema von langer hans · begonnen am 14. Jun 2007 · letzter Beitrag vom 15. Jun 2007
Antwort Antwort
langer hans

Registriert seit: 8. Mär 2007
Ort: Bad Nauheim
32 Beiträge
 
Delphi 6 Personal
 
#1

Stringgrid sortieren

  Alt 14. Jun 2007, 13:24
Hallo!
Mein Problem ist folgendes. In ein Stringgrid werden Zufallszahlen eingefügt, die in die Reihe darunter sortiert ausgegeben werden.
Das wird mit einer modifizierten Versoion einer funktion gelösst die die kleinste Zahl sucht.

Wäre nett, wenn sich das jemand angucken könnte. siehe Anhang.

Delphi-Quellcode:
procedure TForm1.btSortierenClick(Sender: TObject);
var i,j,min,hilfsvar:integer;
begin
for i:=1 to 10 do begin
Stringgrid1.Cells[i-1,2]:=inttostr(kleinstezahl(i,10));
end;
end;
Delphi-Quellcode:
function kleinstezahl(a,b:integer):integer;
var i,vergleich:integer;
begin
vergleich:=zahlen[a];
for i:=a to b do
begin
if zahlen[i]<vergleich then
vergleich:=zahlen[i];

end;
result:=vergleich;
end;
Vielen Dank im Vorraus!!

MfG
Angehängte Dateien
Dateityp: rar stringgrid_151.rar (198,5 KB, 5x aufgerufen)
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2

Re: Stringgrid sortieren

  Alt 14. Jun 2007, 13:26
Zitat von langer hans:
Wäre nett, wenn sich das jemand angucken könnte.
Angeguckt.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
langer hans

Registriert seit: 8. Mär 2007
Ort: Bad Nauheim
32 Beiträge
 
Delphi 6 Personal
 
#3

Re: Stringgrid sortieren

  Alt 14. Jun 2007, 13:28
Danke! Aber hast du auch eine Lösung für mich??

MfG
  Mit Zitat antworten Zitat
Klaus01
Online

Registriert seit: 30. Nov 2005
Ort: München
5.755 Beiträge
 
Delphi 10.4 Sydney
 
#4

Re: Stringgrid sortieren

  Alt 14. Jun 2007, 14:35
Wieso sortierst Du denn nicht das Zahlenarray?
Infos zu Sortierverfahren findest Du hier -> http://www.hrz.uni-dortmund.de/A1/ku...eil2_tag3.html

Grüße
Klaus
Klaus
  Mit Zitat antworten Zitat
langer hans

Registriert seit: 8. Mär 2007
Ort: Bad Nauheim
32 Beiträge
 
Delphi 6 Personal
 
#5

Re: Stringgrid sortieren

  Alt 15. Jun 2007, 16:01
Das ist natürlich auch einen Möglichkeit, allerdings würde ich es gerne genau so lösen...

Ich find einfach den Denklfehler nicht. Der müsste doch bei jedem Schleifendurchlauf die kleinste Zahl in das Stringgrid schreiben...

Danke nochmal für den Link!

MfG langer_hans
  Mit Zitat antworten Zitat
Klaus01
Online

Registriert seit: 30. Nov 2005
Ort: München
5.755 Beiträge
 
Delphi 10.4 Sydney
 
#6

Re: Stringgrid sortieren

  Alt 15. Jun 2007, 16:34
Delphi-Quellcode:
procedure TForm1.btSortierenClick(Sender: TObject);
var
  i,j,min,hilfsvar:integer;
begin
  for i:=1 to 10 do
    begin
      Stringgrid1.Cells[i-1,2]:=inttostr(kleinstezahl(i,10));
    end;
end;
Wer sagt Dir denn, daß die kleinste Zahl immer in der Position kleiner i liegt,
Liegt sie dahinter wird diese Zahl des öfteren als kleinste Zahl erkannt.

Delphi-Quellcode:
function kleinstezahl(a,b:integer):integer;
var i,vergleich:integer;
begin
  vergleich:=zahlen[a];
  for i:=a to b do
    begin
      if zahlen[i]<vergleich then
         vergleich:=zahlen[i];

    end;
  result:=vergleich;
end;
Wenn Du hier die kleinste Zahl ermittelt hast
mußt Du sie an die a-te Position des Array schieben
und die Zahl von der a-ten Position an die Position der kleinsten Zahl.

Das nennet sich sortieren durch vertauschen.

Ist auch in dem Link erklärt.

Grüße
Klaus
Klaus
  Mit Zitat antworten Zitat
langer hans

Registriert seit: 8. Mär 2007
Ort: Bad Nauheim
32 Beiträge
 
Delphi 6 Personal
 
#7

Re: Stringgrid sortieren

  Alt 15. Jun 2007, 16:51
Zitat von Klaus01:
Delphi-Quellcode:
procedure TForm1.btSortierenClick(Sender: TObject);
var
  i,j,min,hilfsvar:integer;
begin
  for i:=1 to 10 do
    begin
      Stringgrid1.Cells[i-1,2]:=inttostr(kleinstezahl(i,10));
    end;
end;
Wer sagt Dir denn, daß die kleinste Zahl immer in der Position kleiner i liegt,
Liegt sie dahinter wird diese Zahl des öfteren als kleinste Zahl erkannt.
Aber das sagt doch garnicht, dass die Zahl an einer Position kleiner i liegt. Die Grenze wird doch immer um 1 nach oben verschoben, so wie es auch in dem Link steht.
Zitat:
Delphi-Quellcode:
function kleinstezahl(a,b:integer):integer;
var i,vergleich:integer;
begin
  vergleich:=zahlen[a];
  for i:=a to b do
    begin
      if zahlen[i]<vergleich then
         vergleich:=zahlen[i];

    end;
  result:=vergleich;
end;
Wenn Du hier die kleinste Zahl ermittelt hast
mußt Du sie an die a-te Position des Array schieben
und die Zahl von der a-ten Position an die i-te.

Das nennet sich sortieren durch vertauschen.

Ist auch in dem Link erklärt.

Grüße
Klaus
Die Funktion gibt mir doch die kleinste Zahl innerhalb des immer kleiner werdenden unsortierten Bereichs an. Das klappt ja auch bei der ersten zhal ganz gut... Ich will die Zahlen ja anich im Array sortieren.

Es tut mir echt Leid, dass ich es nicht verstehe, aber trotzdem Danke für die Hilfe!!!
  Mit Zitat antworten Zitat
Klaus01
Online

Registriert seit: 30. Nov 2005
Ort: München
5.755 Beiträge
 
Delphi 10.4 Sydney
 
#8

Re: Stringgrid sortieren

  Alt 15. Jun 2007, 18:12
Mit Deinem Code läuf das so:

z.B. Zahlen im Array : 9 2 8 1 4 7 8 ..

Nach dem ersten Durchlauf (i=1) bekommst Du die
1 als kleinste Zahl.

Nach dem zweiten Durchlauf (i=2) bekommst Du die
1 als kleinste Zahl. Warum , weil die 1 immer noch an der
gleichen Position steht wie zuvor.

Nach dem dritten Durchlauf (i=3) bekommst Du die
1 als kleinste Zahl.

Nach dem vierten Durchlauf (i=4) bekommst Du die
1 wieder als kleinste Zahl.

Nach dem fünften Durchlauf (i=5) bekommst Du die
4 als kleinste Zahl. Wo ist die 2 geblieben?

und so geht das weiter, es gehen Zahlen verloren und
es werden Zahlen wiederholt.

Grüße
Klaus
Klaus
  Mit Zitat antworten Zitat
langer hans

Registriert seit: 8. Mär 2007
Ort: Bad Nauheim
32 Beiträge
 
Delphi 6 Personal
 
#9

Re: Stringgrid sortieren

  Alt 15. Jun 2007, 18:43
Bingo!!!
Jetzt hab ichs verstanden!!! Vielen Dank. Ich probiers dann demnächst mal aus und meld mich dann nochmal.

Vielen Dank und MfG langer_hans

EDIT: Ich habs geschafft! hier noch mal der erfolgreiche Code:
Delphi-Quellcode:
function kleinstezahl(a,b:integer):integer;
var i,vergleich:integer;
begin
 vergleich:=zahlen[a];
  for i:=a to b do
   begin
    if zahlen[i]<vergleich then
     begin
      vergleich:=zahlen[i];
      zahlen[i]:=zahlen[a];
      zahlen[a]:=vergleich;
     end;
   end;
 result:=vergleich;
end;
Vielen Dank nochmal!!
  Mit Zitat antworten Zitat
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 06:22 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