a FOR loop and floating variables

Martin Drašar drasar at ics.muni.cz
Thu May 2 11:47:57 PDT 2013


Dne 2.5.2013 20:14, Carlos napsal(a):
> I have this code :
>
> import std.stdio;
> import std.c.stdlib;
> void main()
> {
> int fahr;
> write("F\tC\n");
> for (fahr = 0; fahr <= 300; fahr = fahr + 20)
> write(fahr, "\t", (5.0/9.0)*(fahr-32), "\n");
> write("Done!\n");
> exit (0);
> }
>   Which works. but if I change the "5.0" for "5" I get cero on the
> celsius side.
>
> import std.stdio;
> import std.c.stdlib;
> void main()
> {
> int fahr;
> write("F\tC\n");
> for (fahr = 0; fahr <= 300; fahr = fahr + 20)
> write(fahr, "\t", (5/9)*(fahr-32), "\n");
> write("Done!\n");
> exit (0);
> }
>
> So why is this ?

Hi Carlos,

the second code performs integral division which very much behave like 
floating-point division, but the fractional part is chopped off.

  5/9 ~ 0.556 => 0
10/9 ~ 1.111 => 1

If you want precise (i.e. floating point) results, you have to have at 
least one float or double in your equation.

This would work:

write(fahr, "\t", (5.0/9)*(fahr-32), "\n");

Regards,
Martin


More information about the Digitalmars-d-learn mailing list