C&C++   发布时间:2022-04-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了c – 为什么我从std :: fmod和std :: remainder获得不同的结果大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
在下面的示例app中,我使用std :: fmod计算从953除以0.1的浮点余数

我期待的是,自953.0 / 0.1 == 9530,那std :: fmod(953,0.1)== 0

我得到0.1 – 为什么会这样?

请注意,使用std :: remainder我得到了正确的结果.

那是:

std::fmod     (953,0.1) == 0.1 // unexpected
std::remainder(953,0.1) == 0   // expected

两个功能间的区别:

根据cppreference.com

> std :: fmod计算以下内容

恰好是值x – n * y,其中n是x / y,其小数部分被截断

> std :: remainder计算以下内容

恰好是值x – n * y,其中n是最接近精确值x / y的积分值

根据我的输入,我希望两个函数有相同的输出.为什么不是这样?

范例app:

#include <iostream>
#include <cmath>

bool is_zero(double in)
{
    return std::fabs(in) < 0.0000001;
}

int main()
{
    double numerator   = 953;
    double denominator = 0.1;

    double quotient = numerator / denominator;
    double fmod     = std::fmod     (numerator,denominator);
    double rem      = std::remainder(numerator,denominator);

    if (is_zero(fmod))
        fmod = 0;
    if (is_zero(rem))
        rem = 0;

    std::cout << "quotient: " << quotient << ",fmod: " << fmod << ",rem: " << rem << std::endl;
    return 0;
}

输出

quotient: 9530,fmod: 0.1,rem: 0

解决方法

欢迎来到浮点数学.这是发生的事情:十分之一不能用二进制精确表示,就像三分之一不能用十进制精确表示一样.结果,除法产生的结果略低于9530. floor操作产生整数9529而不是9530.然后剩下0.1剩余.

大佬总结

以上是大佬教程为你收集整理的c – 为什么我从std :: fmod和std :: remainder获得不同的结果全部内容,希望文章能够帮你解决c – 为什么我从std :: fmod和std :: remainder获得不同的结果所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。