Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Sonstige Fragen zu Delphi (https://www.delphipraxis.net/19-sonstige-fragen-zu-delphi/)
-   -   Ordnen vo Zahlen (https://www.delphipraxis.net/69721-ordnen-vo-zahlen.html)

Klaus01 20. Mai 2006 17:31

Re: Ordnen vo Zahlen
 
@sidorion

die Funktion von marabu macht wohl etwas anderes als die Deine
die marabu Funktion vergleicht zwei Werte.

Deine subtrahiert zwei Werte.

Delphi-Quellcode:
function CompareInteger(i1, i2: Integer): Integer;
begin
  if i1 < i2 then Result := -1 else
  if i1 > i2 then Result := 1 else
  Result := 0;
end;
Delphi-Quellcode:
function CompareInteger(i1, i2: Integer): Integer;
begin
  Result := i2-i1;
end;
Grüße
Klaus

leddl 20. Mai 2006 17:37

Re: Ordnen vo Zahlen
 
Zitat:

Zitat von Klaus01
@sidorion
die Funktion von marabu macht wohl etwas anderes als die Deine

Im Großen und Ganzen nicht ;)

Zitat:

Zitat von Klaus01
die marabu Funktion vergleicht zwei Werte.

... und seine auch ;)
Zitat:

Zitat von Klaus01
Deine suntrahiert zwei Werte.

.. und gibt daher Zahlen <, > und = 0 aus, je nachdem, was für Zahlen übergeben werden. Im Normalfall ist bei so einer Vergleichsfunktion nicht relevant, welche Zahl genau zurückgegeben wird, sondern eher, ob sie < 0 (i1 kleiner i2), > 0 (i1 größer i2) oder = 0 (i1 gleich i2) ist.

Das einzige, was an sidirions Funktion zu bemängeln wäre, ist daß sie gerade verdrehte Werte ausspuckt. Im Normalfall sagt man nämlich "Parameter1 im Vergleich zu Parameter2". Bei ihm ist das genau umgedreht. ;)

//Edit: Was zum Teufel ist "Normall"? :lol: Hab das mal fix in "Normalfall" geändert :lol:

marabu 20. Mai 2006 17:51

Re: Ordnen vo Zahlen
 
Also mir gefällt die Funktion CompareInteger() von sidorion ausgesprochen gut. Meine ist einfach durch code reuse entstanden - sie hat ursprünglich Zeichenketten verglichen.

@leddl: deine Mängelrüge kann ich nicht nachvollziehen.

Freundliche Grüße vom marabu

leddl 20. Mai 2006 18:09

Re: Ordnen vo Zahlen
 
Zitat:

Zitat von marabu
Also mir gefällt die Funktion CompareInteger() von sidorion ausgesprochen gut. Meine ist einfach durch code reuse entstanden - sie hat ursprünglich Zeichenketten verglichen.

@leddl: deine Mängelrüge kann ich nicht nachvollziehen.

Freundliche Grüße vom marabu

:gruebel: Mängelrüge? :gruebel: Ich war doch mit der Funktion absolut einverstanden, bis eben auf die vertauschten Elemente. Bei euren beiden Funktionen kommt eben immer genau das andere heraus ;) Natürlich kann man sagen "ist Geschmackssache, welchen Parameter man zuerst heranzieht", aber normalerweise sagt man eben wirklich "Parameter1 im Vergleich zu Parameter2", was ja auch durchaus Sinn macht. Auch in Java ist das bei der compareTo-Methode genau so definiert:
this < that => Ergebnis < 0
this = that => 0
this > that => Ergebnis > 0

Mobby 20. Mai 2006 18:24

Re: Ordnen vo Zahlen
 
sry leute...aber ich kann euch gerade garnicht folgen. :shock:
ich hab es jetzt auf 3verschiedenen wegen gemacht...also ich hab jeder karte wie oben beschrieben

kartenspiel[1]:='Ka7'...gemacht,
andere variante war:
'Ka7':=inttostr(1) //mit fortlaufenden Zahlen//
und dann die methode, es nach alphabet zu sortieren und dabei jeder karte einen buchstaben //indem fall aa,ab,ac...be// zuzuordnen und dann mit dem "normalen" .Sourted zu ordnen...
nur hat keine der drei varianten zum erfolg geführt...und eure anderen sachen kann ich wie gesagt nicht ganz folgen :gruebel:

marabu 20. Mai 2006 18:25

Re: Ordnen vo Zahlen
 
Axel, du hast eine Ausdrucksweise - da gibt es doch ein einfaches Heilmittel:

Delphi-Quellcode:
function CompareInteger(i1, i2: Integer): Integer;
begin
  Result := -1 * (i2 - i1); // genial
end;
Grüße vom marabu

PS: hatte den Dreher zuerst gar nicht gesehen...

leddl 20. Mai 2006 18:38

Re: Ordnen vo Zahlen
 
Zitat:

Zitat von marabu
Axel, du hast eine Ausdrucksweise

:gruebel: Wie habe ich das jetzt zu verstehen?
Zitat:

Zitat von marabu
- da gibt es doch ein einfaches Heilmittel:
[...]

... oder einfach
Delphi-Quellcode:
function CompareInteger(i1, i2: Integer): Integer;
begin
  Result := i1 - i2;
end;
:zwinker:

Klaus01 20. Mai 2006 18:47

Re: Ordnen vo Zahlen
 
Hallo Mobby,

wenn Du die Karten in das Array reingeschrieben hast
und in der richtigen Ordnung, was willst denn Du dann noch sortieren?

Delphi-Quellcode:
type
  TKartenSpiel = Array [1..32] of string;

var
  KartenSpiel: TKartenSpiel;

begin
  KartenSpiel[1]:='Karo 7';
  KartenSpiel[2]:='Karo 8';
  ...

end;
Dann ist doch die niedrigste Karte auf Position 1
und die höchste auf Position 32. Die sind dann
sortiert - oder nicht?

Um eine Wertigkeit einer Karte zu finden
mußt Du nur die Position finden.

Das kannst Du machen indem Du das Array durchsucht

Delphi-Quellcode:
function findValue(spiel:TKartenspiel;karte:String):Byte;
var
  i:Byte;
  found:Boolean;

begin
  found := false;
  i:=1;

  while not found and i <= 32 do
    begin
      if spiel[i] = karte then
        found:=true;
      inc(i);
    end;

  if found then
    result:=i-1
  else
    result := 0;
end;
Die Karten kannst Du dann anhand ihres Wertes vergleichen.

Delphi-Quellcode:
if findvalue(Kartenspiel,'Karo 7') < findValue(Kartenspiel,'Herz 8') then
   // tue etwas
else
  // tue etwas anderes
Ansonsten sehe ich nicht wo Dein Problem ist.

Grüße
Klaus

Khabarakh 20. Mai 2006 18:53

Re: Ordnen vo Zahlen
 
Zitat:

Zitat von Klaus01
Delphi-Quellcode:
function findValue(spiel:TKartenspiel;karte:String):Byte;
var
  i:Byte;
  found:Boolean;

begin
  found := false;
  i:=1;

  while not found and i <= 32 do
    begin
      if spiel[i] = karte then
        found:=true;
      inc(i);
    end;

  if found then
    result:=i-1
  else
    result := 0;
end;

:gruebel:
Delphi-Quellcode:
function FindValue(ASpiel: TKartenspiel; AKarte: String): Byte;
var
  i: Integer;
begin
  Result := 0;
  for i := Low(ASpiel) to High(ASpiel) do
    if ASpiel[i] = AKarte then
    begin
      Result := i;
      Exit;
    end;
end;

Klaus01 20. Mai 2006 22:17

Re: Ordnen vo Zahlen
 
da habe ich mich mit der Funktion nicht besonders geschickt angestellt.

Delphi-Quellcode:
function findValue(spiel:TKartenspiel;karte:String):Byte;
var
  i:Byte;

begin
  result := 0;
  i:=1;

  while (result = 0) and (i <= High(spiel) do
    begin
      if spiel[i] = karte then
        result:=i;
      inc(i);
    end;

end;
so geht es auch wenn man das exit in der for Schleife nicht mag.

Grüße
Klaus


Alle Zeitangaben in WEZ +1. Es ist jetzt 06:39 Uhr.
Seite 2 von 2     12   

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