java四舍五入成整数的方法

java四舍五入成整数的方法    在java的Math类中,提供了许许多多的和数学计算有关的方法,其中也包括取整的,关于取整的有向下取整的floor(doubled)返回值double,rint(doubled),round(doubled)和round(floatf)。   但是,其中和四舍五入相近的方法只有rint和round方法,如果单独使用这两个方法的话,所得到的结果和我们预期的结果不一样,    比如r…

大家好,又见面了,我是你们的朋友全栈君。

    在java的Math类中,提供了许许多多的和数学计算有关的方法,其中也包括取整的,关于取整的有向下取整的floor(double d)返回值double,rint(double d),round(double d)和round(float f)。

    但是,其中和四舍五入相近的方法只有rint和round方法,如果单独使用这两个方法的话,所得到的结果和我们预期的结果不一样,

    比如round(-1.5)所得到的结果是-1,而不是我们预期的-2;

    而rint(-1.5)得到的结果是-2.0,但是rint(2.5)得到的结果却是2.0,和我们预期的3.0也不一样

java四舍五入成整数的方法java四舍五入成整数的方法

    我们分析一下为什么会这样子,首先看一下round方法的API:

Returns the result of rounding the argument to an integer. The result is equivalent to (long) Math.floor(d+0.5).

Special cases:

  • round(+0.0) = +0.0
  • round(-0.0) = +0.0
  • round((anything > Long.MAX_VALUE) = Long.MAX_VALUE
  • round((anything < Long.MIN_VALUE) = Long.MIN_VALUE
  • round(+infinity) = Long.MAX_VALUE
  • round(-infinity) = Long.MIN_VALUE
  • round(NaN) = +0.0

Parameters
d the value to be rounded.

Returns

  • the closest integer to the argument.

即返回一个和参数相近的整型,其结果相当于(long) Math.floor(d+0.5)的值,对于Math.floor(double d)方法,其结果是d向下取整,所以对于round(-1.5)来说,它的返回值是要加上0.5再向下取整,也就是-1.5+0.5=-1.0,1.0向下取整还是1.0,所以返回的是长整型1,但是计算正数的时候就没有这个问题。比如说round(1.5),计算的就是(long)(1.5+0.5)=(long)2.0=2L,所以对于round方法来说对于负数四舍五入所得到的结果是不正确的。

    然后我们来看一下rint方法的API,这个方法与四舍五入差的有点远。

public static double rint (double d)

Added in API level 1

Returns the double conversion of the result of rounding the argument to an integer. Tie breaks are rounded towards even.

Special cases:

  • rint(+0.0) = +0.0
  • rint(-0.0) = -0.0
  • rint(+infinity) = +infinity
  • rint(-infinity) = -infinity
  • rint(NaN) = NaN
Parameters
d the value to be rounded.
Returns
  • the closest integer to the argument (as a double).

    这个方法也是返回一个和参数相近的整型,当有两个整数的时候,会返回偶数的那个。

也就是说,当遇到几点五的时候,才会遇到两个整数,所以对于rint(-1.5)来说,会有-1.0和-2.0两个整数与-1.5相近,但是他会取偶数-2.0,。对于rint(-1.3)只有一个整数-1.0与-1.3接近,所以此时不会有误差。但是对于rint(2.5),有2.0和3.0与2.5接近,他会返回与我们预期不一样的偶数2.0,rint(-2.5)会返回-2.0,所以对于rint方法,当遇到偶数点五的时候,结果会不一样。

    综合上述,如果想用round方法就得解决负数问题,所以可以用绝对值Math.abs方法来解决。下面为代码:

方法一:

public double run(double num){
    double a=Math.signum(num); //判断是正数负数还是0,负数返回-1.0,正数返回1.0
    if(a<0.0)
        return 0.0-Math.round(Math.abs(num));
    return Math.round(num);
}

    如果想用rint方法就得解决偶数点五的问题,下面为代码:

方法二:

public double run(double num){
   if(Math.floor(Math.abs(num))%2!=0)
       return Math.rint(num);
   if(five(num))
       if(Math.signum(num)<0.0)
       return Math.rint(num)-1.0;
   else if(Math.signum(num)>0.0)
       return Math.rint(num)+1.0;
   return Math.rint(num);

}
public boolean five(double n){
    String[] split = String.valueOf(n).split("\\.");
    if(split[1].startsWith("5"))
        return true;
    else return false;
}

    当然也有其他方法,比如用保留小数的方法string的格式化方法都行   

因为方法二效率低,所以建议使用方法一。

本人第一次写博客,还是学生,所以有不足之处请指正,请谅解不足或错误之处,谢谢!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/143511.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 纯CSS实现自定义单选框和复选框

    纯CSS实现自定义单选框和复选框<!DOCTYPEhtml><html> <head> <metacharset=”utf-8″> <title></title> <styletype=”text/css”> #main{ display:flex; justify-content:center; align-items:center; flex-wrap:wrap; } .

  • 2048游戏逻辑

    2048游戏逻辑

  • VMware安装Centos7超详细过程(图文)[通俗易懂]

    VMware安装Centos7超详细过程(图文)[通俗易懂]原文:https://www.jianshu.com/p/ce08cdbc4ddb?utm_source=tuicool&utm_medium=referral本篇文章主要介绍了VMware安装Centos7超详细过程(图文),具有一定的参考价值,感兴趣的小伙伴们可以参考一下1.软硬件准备软件:推荐使用VMwear,我用的是VMwear12镜像:CentOS7,如…

  • opkg list 报错

    opkg list 报错opkglistCollectederrors:*opkg_conf_load:Couldnotlock/var/lock/opkg.lock:Resourcetemporarilyunavail echo”nameserver114.114.114.114″>/tmp/resolv.conf rm-f/var/lock/opkg.lock opkgupdate

  • 3D视频编码(3d打印技术介绍)

    3D-HEVC编码框架3D-HEVC编码结构是对HEVC的扩展,每个视点纹理及深度图编码主要采用HEVC编码框架,但在其基础上增加了一些新的编码技术,使其更有利于深度图和多视点的编码。图13D-HEVC编码结构如上图所示,3D-HEVC编解码结构和MVC类似。图中所有输入的视频图像和深度图像是同一时刻,不同拍摄位置的场景,这些图像组成一个存取层。在同一个存取层中,首先对独立视点(基准视点…

  • findwindowex函数用法_内核防止findwindow

    findwindowex函数用法_内核防止findwindow函数功能:该函数获得一个顶层窗口的句柄,该窗口的类名和窗口名与给定的字符串相匹配。这个函数不查找子窗口。在查找时不区分大小写。函数型:HWNDFindWindow(LPCTSTRIpClassName,LPCTSTRIpWindowName);参数:IpClassName:指向一个指定了类名的空结束字符串,或一个标识类名字符串的成员的指针。IpWindowName:指向一个指定了窗口名(窗…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号