涉及链接图片以及任何转载内容,如有冒犯,请及时联系我删除
遗留问题 为什么float 类型的数据 为什么不是一个精确值而是一个近似值
#include <stdio.h>
void main()
{
float PI = 3.14159;
int s,r = 5;
s = r * r*PI;
printf("s=%d\n", s);
}
输出结果 s=75
PI 是实型 s,r 为整型 运行的时候先将 s,r转换为double,进行计算,因为s申明为整型,所以程序会将计算结果取整变成整型,取整会导致精度下降
#include <stdio.h>
void main()
{
float s, PI = 3.14159;
int r = 5;
s = r * r*PI;
printf("s=%d\n", s);
}
输出结果:s=1073741824
修改后,将s 也申明为实型 ,计算结果就不会取取整,精度自然不会下降
但是s的值变成了1073741824,显然与真确的数值相差巨大
可以看到这里的PI=3.14159 实际上是一个近似值(3.14158999999999883) 所以数据溢出了
解决:将输出的 printf(“s=%d\n”,s); 改为printf("%e"\n,s);运行结果为7.853975e+01
%d 整型输出
%e以指数形式输出实数
当然这里也可以用%f 运行结果为78.535749