![]() |
Re: Mehere Werte auf gleichheit überprüfen
@Hagen:
Mit "and" bzw. "or" ist natürlich auch eine Möglichkeit ;) Wobei man jetzt wieder darüber diskutieren könnte, was schneller ist, wenn (Value[1] = Value[2]) false ist. Schließlich hätte man bei ner Zuweisung ne Schreiboperation, während ein if-Konstrukt in diesem Fall nur lesen würde. |
Re: Mehere Werte auf gleichheit überprüfen
Zitat:
Wenn nicht:
Delphi-Quellcode:
Nicht schlagen, wenn's BS ist *dummer .Net Fritze ist :P *
function AllEqual(const values : array of Byte) : Boolean;
var firstElement, lastElement, currentElement : PByte; begin if Length(values) > 1 then begin firstElement := @values[Low(values)]; lastElement := @values[High(values)]; currentElement := firstElement; while Integer(currentElement) < Integer(lastElement) do begin Inc(currentElement); Result := currentElement^ = firstElement^; if not Result then Exit; end; end else Result := true; end; |
Re: Mehere Werte auf gleichheit überprüfen
Zitat:
Heutige CPUs sind daraufhin optimiert gerade den Array-indizerten-record-basierten Zugriff auf den Speicher zu ermöglichen. Dies ist bei weitem effizienter, sowohl im Verständnis, Geschwindigkeit und Verbrauch an Speicher für den Code. Die effizienteste Lösung dürfte darin bestehen ein Element im Array[] zu finden das NICHT identisch mit dem ersten Element des Arrays[] ist. Auf CPU Ebene gibt es den Befehl "scanne Speicherarray auf einen Wert <> X" -> REP SCASD Gruß Hagen |
Re: Mehere Werte auf gleichheit überprüfen
hehe, bin schon ganz lieb und ruhig. Zumindest solange du nun auch einen Schnipsel rausrückst. :mrgreen:
Wer A sagt muss auch ... Code tippen. :P |
Re: Mehere Werte auf gleichheit überprüfen
Zitat:
Und außerdem ist es ziemlich logisch die 2. Konstruktion zu nehmen, weil if nichts anderes ist als zu überprüfen ob das zwischen if und then true ist, und dann bestimmte Dinge zu machen! D.h. das Value[1] = Value[2] ein Bollean zurückgeben MUSS, weil ansonsten würde der Compiler meckern! |
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:15 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