两个相同值的双精度浮点数相减,结果竟然不是零,该如何处理

两个相同值的双精度浮点数相减,结果竟然不是零
在调试时,两个相同值的浮点数竟然不是零,求原因啊

------解决方案--------------------
编译器问题,存在误差,比如double a = 3.0;有可能编译器中a的实际值是3.000001或者是2.9999999,所以在比较两个浮点数的差值是否为0时可以用如下方式比较
------解决方案--------------------
if (a-b<0.000001 || a-b>-0.000001)
{
}
------解决方案--------------------
探讨
引用:

3、 题目描述:
在超市里,最大的问题就是给钱和找钱。纸币类型有100,50,20,10, 5,2,1,0.5,0.2,0.1这么多的面值。为了完成一次固定数额的交易,例如你要买31元的物品,你可能给50元,这样对方要找回19(10+5+2+2)元,共要用五张纸币,或者你给51元,这样对方要找回20元,只要三张纸币。
所以你也会希望交易所需要用到的纸币数目尽可能地……

------解决方案--------------------
C/C++ code
    if (best < -0.00001 || best > 0.00001)     //改成这样
    {
        times +=solve(best);
    }

------解决方案--------------------
double型因精度问题,判断一double型变量是否为0,应是判断一个值是否落在一个范围内
如[-0.0000001 0.0000001],
------解决方案--------------------
用整型,计算机中,整型数据的精度最高!
------解决方案--------------------
LS正解!
判断浮点数相等只要判断两数差的绝对值小于一个精瓶度值就可以了。
------解决方案--------------------
探讨

用整型,计算机中,整型数据的精度最高!

------解决方案--------------------
用10进制小数不能精确表示某些三进制小数0.1(3)=0.33333333333……(10)
同理,用二进制小数也不能精确表示某些10进制小数。

------解决方案--------------------
VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)”

提醒:
“学习用汇编语言写程序”

“VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)”
不是一回事!

不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!

不要写连自己也预测不了结果的代码!