C语言运算表达式中的小数按什么数据类型处理
发布网友
发布时间:2022-05-09 06:23
我来回答
共1个回答
热心网友
时间:2024-01-28 23:25
在C语言中,我们使用float、double 来表示小数,
在内存中的形式如下所示:
类型 符号 指数 尾数
float 1bit 8bit 23bit
double 1bit 11bit 52bit
输出 float 使用 %f 控制符,输出 double 使用 %lf 控制符,实例如下所示:
#include <stdio.h>
#include <stdlib.h>
int main()
{
float a=128.101;
float b=0.302f;
float c=1.23002398f;
double d=123;
double e = 78.429;
printf("a=%f \nb=%f \nc=%f \nd=%lf \ne=%lf\n", a, b, c, d, e);
system("pause");
return 0;
}
运行结果:
a=128.100998
b=0.302000
c=1.230024
d=123.000000
e=78.429000
对代码的说明:
1) %f 默认保留六位小数,不足六位以 0 补齐,超过六位按四舍五入截断。
2) 将整数赋值给 float 变量时会转换为小数。
3) 小数默认为 double 类型,加上后缀f才是float类型。
4) 由于内存有限,小数的精度受限,所以输出 a 时只能获得一个近似数。