关于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