Hi Ich möchte eine Zahl prüfen, ob sie gerade ist. Was genau macht folgende Funktion: if (zahl % 2 == 0);
Nichts dank dem Strichpunkt hinter dem if, ein wenig Rechenzeit verschwenden. Bei richtiger Anwendung: %2 => modulo 2 -> den Rest einer Division durch 2 zurückgeben Ist der 0 -> gerade Ist der 1 -> ungerade
Rambo schrieb: > Hi > > Ich möchte eine Zahl prüfen, ob sie gerade ist. Was genau macht folgende > Funktion: > > if (zahl % 2 == 0); wenn die zahl mod 2 = 0 ist, ist sie gerade. Das ist einer der Fälle, wo die höhere Programmiersprache extrem uneffektiv ist. Eine Zahl ist gerade, wenn das kleinste Bit = 0 ist, das lässt sich mit Assembler mit einem einzigen Befehl prüfen und in einem Maschinentakt statt einer kompletten Division. Gruss Reinhard
>Das ist einer der Fälle, wo die höhere Programmiersprache extrem >uneffektiv ist. Eine Zahl ist gerade, wenn das kleinste Bit = 0 ist, das >lässt sich mit Assembler mit einem einzigen Befehl prüfen und in einem >Maschinentakt statt einer kompletten Division. Das liegt eher am Programmierer als an der Sprache. if((zahl & 1) == 0){}
Noe, höchstens an den Compiler-Flags. das % 2erPotenzKonstante wird als & umgesetzt
>das % 2erPotenzKonstante wird als & umgesetzt
Das habe ich beim C18 schon anders gesehen ;)
Er tut es nähmlich nicht. Zumindest die
Version die ich mal benutzt habe.
Reinhard Kern schrieb: > Das ist einer der Fälle, wo die höhere Programmiersprache extrem > uneffektiv ist. Eine Zahl ist gerade, wenn das kleinste Bit = 0 ist Sehr schlechtes Beispiel für den Unterschied, denn mit Hochsprache hat das überhaupt nichts zu tun. Das lässt sich in Hochsprache genauso realisieren und man kann das auch in Assembler per Division abwickeln. Ausserdem ist es seit jeher Aufgabe eines Compilers, solche Trivialitäten aufeinander abzubilden. Wenn ein heutiger Compiler es in diesem Fall nicht schafft, dann ist das dem Compiler anzulasten, nicht der Sprache.
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.