C语言运算表达式中的小数按什么数据类型处理

 我来答
紫轩玥桦
2017-01-18 · TA获得超过144个赞
知道小有建树答主
回答量:103
采纳率:62%
帮助的人:49.5万
展开全部
在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 时只能获得一个近似数。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式