浮点数的表示是不精确的,不能直接比较两个数是否完全相等,一般都是在允许的某个范围内认为像个浮点数相等,如有两个浮点数a,b,允许的误差范围为1e-6,则abs(a-b)<=1e-6,即可认为a和b相等。还有一种方法就是扩大再取整,比如a=5.23,b=5.23,直接比较 a==b一般为false,但是a和b都扩大一百倍,然后强制转换为int类型,再用==比较就可以了  float型变量和“零值”比较的方法: const float EPSINON = 0.000001; if ((x >= - EPSINON) && (x <= EPSINON)) 浮点型变量并不精确,其中EPSINON是允许的误差(即精度),所以不可将float变量用“==”或“!=”与数字比较,应该设法转化成“>=”或“<=”形式。如果写成if (x == 0.0),则是错误的。 因为1.0在计算机中可能存为0.999999或1.00001等,很难恰好是1.0

相关文章:

  • 2021-07-20
  • 2021-09-19
  • 2022-01-24
  • 2022-01-02
  • 2022-12-23
  • 2021-10-25
  • 2022-12-23
  • 2021-08-08
猜你喜欢
  • 2021-12-25
  • 2021-12-18
  • 2022-12-23
  • 2021-06-28
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案