看下面两段代码,告诉我答案差异很大的原因。
#include<stdio.h>
int main() {
float a = 0.9;
if(a<0.9)
printf("hi"); // This will be the answer
else
printf("bye");
return 0;
}
如果我们将 0.9 更改为 0.8,则会打印 else 的语句:
#include<stdio.h>
int main() {
float a = 0.8;
if(a<0.8)
printf("hi");
else
printf("bye");//this will be the answer
return 0;
}
那么为什么当我们只改变一个数字时输出会改变?
最佳答案
这个错误是由于浮点精度,因为你正在比较 float
输入 double
值(value)。尝试将它与浮点文字进行比较:if(a<0.8f)
我建议你阅读根据 wikipedia article , 它详细解释了为什么会发生错误。
关于c++ - float 比较给出不同的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7580352/