当除数和被除数都是整形时,即使将函数定义为浮点类型,进行的也是整形计算,显示的结果为整形。
如以下程序:
#include <stdio.h>
int main()
{
int a = 2, b = 1;
float r;
r = (a + b) / 2;
printf("%.1f", r);
return 0;
}
本应输出1.5,可输出结果为1.0,表示函数进行的是整形运算,将小数点之后的数据舍弃;
当除数和被除数中存在浮点数时,进行的就是浮点数计算,计算结果为浮点数。
如以下程序:
#include <stdio.h>
int main()
{
int a = 2, b = 1;
float r;
r = (a + b) / 2.0;
printf("%.1f", r);
return 0;
}
输出结果为1.5;
或者可以转化数据类型,在(a+b)之前加上(float)。
如以下程序:
#include <stdio.h>
int main()
{
int a = 2, b = 1;
float r;
r = (float)(a + b) / 2;
printf("%.1f", r);
return 0;
}
输出结果为1.5.
总结:
1.当除数和被除数都是整形时,即使将函数定义为浮点类型,进行的也是整形计算,显示的结果为整形;
2.当除数和被除数中存在浮点数时,进行的就是浮点数计算,计算结果为浮点数。