| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4869 人关注过本帖
标题:关于float的输出问题
取消只看楼主 加入收藏
icemanfire
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2009-10-2
结帖率:0
收藏
已结贴  问题点数:20 回复次数:1 
关于float的输出问题
#include <math.h>
main()
{
float a,b,c,s,area;
scanf(“%f,%f,%f”,&a,&b,&c);
s=1.0/2*(a+b+c);
area=sqrt(s*(s-a)*(s-b)*(s-c);
printf(“a=%7.2f,b=%7.2f,c=%7.2f\n”,a,b,c,s);
printf(“area=%7.2f\n”,area);
}
输入3,4,6
为什么改成s=1/2*(a+b+c) printf(“a=%f,b=%f,c=%f\n”,a,b,c,s);
printf(“area=%f\n”,area);
输出结果s=0.000000   area=-0.000000
为什么要写成a=%7.2f,为什么不写成a=%f
main()
{
double x,y;
x=1111111111111.111111111;
y=2222222222222.222222222;
printf((“%f”,x+y);
}
输出结果为
3333333333333.333010
为什么输出结果不是3333333333333.333
main()
{
float x,y;
x=111111.111;
y=222222.222;
printf((“%f”,x+y);
}
输出结果为333333.328125
为什么输出结果不是333333.3

搜索更多相关主题的帖子: float 输出 
2009-10-02 16:59
icemanfire
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2009-10-2
收藏
得分:0 
谢了,只是4楼说的关于double型的数据有效位数是15-16。这个语句printf((“%f”,x+y);输出的结果不应该是float型吗?
2009-10-02 20:04
快速回复:关于float的输出问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015961 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved