C语言除法类型

       当除数和被除数都是整形时,即使将函数定义为浮点类型,进行的也是整形计算,显示的结果为整形。

如以下程序:

#include
int main()
{
    int a = 2, b = 1;
    float r;
    r = (a + b) / 2;
    printf("%.1f", r);
    return 0;
}

本应输出1.5,可输出结果为1.0,表示函数进行的是整形运算,将小数点之后的数据舍弃;

当除数和被除数中存在浮点数时,进行的就是浮点数计算,计算结果为浮点数。

如以下程序:

#include
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
int main()
{
    int a = 2, b = 1;
    float r;
    r = (float)(a + b) / 2;
    printf("%.1f", r);
    return 0;
}

输出结果为1.5.

总结:

1.当除数和被除数都是整形时,即使将函数定义为浮点类型,进行的也是整形计算,显示的结果为整形;

2.当除数和被除数中存在浮点数时,进行的就是浮点数计算,计算结果为浮点数。

你可能感兴趣的:(C语言学习,c语言,开发语言)