float f6=51.232f;

printf("%f\n",f6);

这个的输出结果默认保留小数点六位,结果是51.231998,这个默认的六位不管你限制输出与否,里面只保留了六位,如果你限制输出到七位(%.7f),那么输出的结果是前五位准确,后面的数是近似值。

例如:

#include<stdio.h>
int main(){
    float f5=51.23232366342f;
    printf("%.7f\n",f5);

} 

结果如下:

float默认保存6位小数,通过类比知道double保留12位小数

限制输出不仅可以这样

printf("%.2f\n",f);

还可以这样

printf("%.*lf",2,f);

都是表达的是保留两位小数

 

 还想再强调一下,这个六位是特殊,还需要研究,或许对于我一个马上大三的学生来说,了解到这里就够了,但我想继续研究。

再就是double类型的值,或许可以和这个类比一下。等下再看看double类型的值。

 

类比一下double

我去试了一下的,类比推理成功,double自动保留的是12位。和float其他一样的

所以最后得出一个结论,当你用float保存小数时,不能大于六位了,用double时就不要大于12位(一般不会有这么大吧,额,也有这种情况,毕竟整数都有大整数),在我上面的例子里面都有错误,比如

#include<stdio.h>
int main(){
    float f5=51.23232366342f;
    printf("%.7f\n",f5);

} 
float f5=51.23232366342f;这一行就是我说的用float时,不要大于6位,显然我这个大于六位了,例子嘛,看看就好。double类似,自己推吧,打代码自己打打也可以的,加深影响。

有问题欢迎留言,大家一起学习。

相关文章:

  • 2021-11-29
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-12-18
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-08-11
  • 2022-12-23
  • 2022-02-27
  • 2022-01-13
相关资源
相似解决方案