c – 除零除法:检查除数的表达式不会导致零与检查除数不为零?

由于减法中的浮点误差,在以下情况下是否可以除零?
float x,y,z;
...
if (y != 1.0)
    z = x / (y - 1.0);

换句话说,以下是否更安全?

float divisor = y - 1.0;
if (divisor != 0.0)
    z = x / divisor;

解决方法

这样可以防止你正好除以零,但这并不意味着仍然不会以/ -inf为结果.分母仍然可以足够小,以便答案不能用双重表示,你最终会得到一个inf.例如:
#include <iostream>
#include <limits>

int main(int argc,char const *argv[])
{
    double small = std::numeric_limits<double>::epsilon();
    double large = std::numeric_limits<double>::max() / small;
    std::cout << "small: " << small << std::endl;
    std::cout << "large: " << large << std::endl;
    return 0;
}

在这个程序中,small是非零的,但是它很小,超出double的范围并且是inf.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...