I know this is a simple questions, but it came up when I was coding and I am wondering how it works now. So, my first question is that when printf is given an integer like b
You used the wrong format specifiers It should be
int a = 2, b = 5, result = 0;
result = b/a*a;
printf("%d\n", result);
...
double a = 2, b = 5, result = 0;
result = b/a*a;
printf("%f\n", result);
Basically because if you interpret the bits that make up a small integer as if they were a double, it looks like the double value for 0. Whereas if you interpret the bits that represent a small double value as an integer, it looks like something more interesting. Here is a link to a page that describes how the bits are used to represent a double: http://en.m.wikipedia.org/wiki/IEEE_floating_point . With this link and a little patience, you can actually work out the integer value that a given double would be interpreted as.