加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C四舍五入到FE_TONEAREST

发布时间:2020-12-16 10:01:06 所属栏目:百科 来源:网络整理
导读:任何人,请解释为什么舍入0.5到FE_TONEAREST给0?它不应该给出“1”的结果吗?有没有办法来解决这个问题? #include fenv.h#include iostream#include cmathint main() { fesetround(FE_TONEAREST); std::cout "Rounding 0.5 to nearest = " std::rint(0.5) s
任何人,请解释为什么舍入0.5到FE_TONEAREST给0?它不应该给出“1”的结果吗?有没有办法来解决这个问题?

#include <fenv.h>
#include <iostream>
#include <cmath>

int main() {
    fesetround(FE_TONEAREST);
    std::cout << "Rounding 0.5 to nearest = " << std::rint(0.5) << std::endl;
    return 0;
}

coliru上的可运行代码:http://coliru.stacked-crooked.com/a/9c179ca56f251628

解决方法

FE_TONEAREST使std :: rint将中间情况(±n.5)舍入为最接近的偶数整数值. 0是偶数.

如果你在这种模式下使用std :: round,那么中途情况会向上“向上”(远离零),这将导致1.

见documentation for std::rint.

为什么你可能想要这种不寻常的舍入形式是explained over on Mathematica.SE.(所以你的数据不会全部转向一个方向).

顺便说一下,C提供了标准头文件的正确包装版本,并将名称添加到std命名空间(虽然这在这里几乎不重要):通常#include< cfenv>而不是#include< fenv.h>.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读