论如何使用double实现取余计算

warning: 这篇文章距离上次修改已过358天,其中的内容可能已经有所变动。

Java 里面由于浮点数不精确的特性,并不能直接用:m - (m / n)* n 计算,应该使用下面的方式

 /**
     * 求浮点数的取余计算:m/n=x...r
     * m、n 不同号的话:返回 m - Math.ceil (m / n) * n; 【  ceil 向上取整  】
     * m、n 是同号的话:返回 m - Math.floor (m / n) * n;  【  floor 向下取整  】
     *
     * @param m 被除数(m为负数则余值为负数,m为正数则余值为正数)
     * @param n 除数
     * @return 余数
     */
    public static double mod(double m, double n) {
        return (m / n) > 0.0 ? m - Math.floor(m / n) * n : m - Math.ceil(m / n) * n;
    }

上面的计算遇到 mod(Double.MAX_VALUE, 0.1) 的情况下会出现无穷大的结果,不过这是正常情况,不需要关心(即使看起来不正常)

但是在 Java、C/C++ 等语言中,整数 a%b = a-a/b*b

本篇转自:https://zhuanlan.zhihu.com/p/110822409

版权声明 ▶ 本网站名称:我的学习笔记
▶ 本文链接:https://ooolo.net/article/117.html
▶ 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行核实删除。
▶ 转载本站文章需要遵守:商业转载请联系站长,非商业转载请注明出处!!!

none
最后修改于:2023年04月28日 13:36

添加新评论

icon_mrgreen.pngicon_neutral.pngicon_twisted.pngicon_arrow.pngicon_eek.pngicon_smile.pngicon_confused.pngicon_cool.pngicon_evil.pngicon_biggrin.pngicon_idea.pngicon_redface.pngicon_razz.pngicon_rolleyes.pngicon_wink.pngicon_cry.pngicon_surprised.pngicon_lol.pngicon_mad.pngicon_sad.pngicon_exclaim.pngicon_question.png