Hi, ich möchte gerade zahlen runden lassen, jedoch gibts anscheinend keine Rundungsfunktion. Ich habe die math.h eingebunden, jedoch kommt nur die Meldung, dass round undefined ist. Gibts ne andre möglichkeit, ohne sich eine rundungsfunktion selbst zu schreiben? Thnx SiO2
> ich möchte gerade zahlen runden lassen
Du meinst vermutlich "ganze Zahlen", also Integer-Werte...
Es gibt da im Prinzip zwei Möglichkeiten:
1.: Zur Zahl 0.5 addieren und dann nach integer konvertieren (das bringt
aber Gleitkommaarithmetik mit sich und ist nicht sinnvoll, wenn man
nicht sowieso schon Gleitkommafunktionen im Programm hat, da dies den
Code extrem aufbläht).
2.: Rundungsprobleme bei Integer-Werten treten eigentlich nur bei
Divisionen auf. In diesem Fall kann man sich mit einem Trick behelfen:
Vor der Division den Dividenden mit 2 multiplizieren. Nach der Division
das Endergebnis mit
Endergebnis = Ergebnis/2 + Ergebnis%2
berechnen. Die Multiplikation mit 2 geht aber nur dann reibungslos, wenn
sichergestellt ist, dass kein Zahlenbereichsüberlauf stattfindet (also
wenn gewährleistet ist, dass Dividend*2 und Endergebnis*2 noch im
Zahlenraum des betreffenden Datentyps sind). Ist das nicht
gewährleistet, muss man vor der Rechnung auf den nächstgrößeren Datentyp
casten (bei int also auf long), was aber meist immer noch schneller und
ressourcenschonender ist als eine Gleitkommaberechnung.
Ich arbeite mit Double und divisionen, wo ich am Ende nen long benötige. Und das Casten haut ne menge weg. Die einfache Addition von 0.5 ist auch nur ne notlösung. Werde auch mal weiter googlen. SiO2
Wenn Du sowieso in Gleitkomma rechnest, wo liegt dann das Problem? Genau in diesem Fall ist doch die Addition von 0.5 die einfachste Lösung... Eine Rundungsfunktion, so es sie denn gibt, macht vermutlich auch nichts anderes, und wenn doch, dann wahrscheinlich mit wesentlich mehr Code.
>Die einfache Addition von 0.5 ist auch nur ne notlösung.
Stimmt! Negative Werte kann man so nicht runden :-)
Für Faule: sprintf() und dann sscanf().
> Stimmt! Negative Werte kann man so nicht runden :-) Stimmt tatsächlich... > Für Faule: sprintf() und dann sscanf(). ...und für Leute mit zuviel Speicher.
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.