java 四舍五入和四舍六入五平分

本文介绍了两种常见的四舍五入方法:经典四舍五入和银行家算法(四舍六入五平分)。详细解释了银行家算法如何减少长期计算中的累积误差,并通过示例展示了其在Java中的实现。

 

1.第一种 四舍五入

方法1:
System.out.println(Math.round(66.5));



方法2:
BigDecimal   b   =   new   BigDecimal(120.00);
 //经典的四舍五入。
 double   f1   =   b.setScale(0,RoundingMode.HALF_UP).doubleValue();

 

 

 

 

 

第二种 ,四舍六入五平分(银行家算法)

方法1:
NumberFormat nfFormat = NumberFormat.getInstance();
nfFormat.setMaximumFractionDigits(0);
System.out.println(nfFormat.format(64.5));//前一位是偶数,则不进位。结果是64。
System.out.println(nfFormat.format(65.5));//前一位是基数,则进位。结果是66。

  

方法2:
BigDecimal   b   =   new   BigDecimal(65.5);
double   f1   =   b.setScale(0,RoundingMode.HALF_EVEN).doubleValue();
 System.out.println(f1);

 

 

 

 

 

我们都知道银行的盈利渠道主要是利息差,它从储户手里收集资金,然后放贷出去,期间产生的利息差就是银行所获得的利润。如果我们采用平常四舍五入的规则话,这里采用每10笔存款利息计算作为模型,如下:

      四舍:0.000、0.001、0.002、0.003、0.004。这些舍的都是银行赚的钱。

      五入:0.005、0.006、0.007、0.008、0.009。这些入的都是银行亏的钱,分别为:0.005、0.004、.003、0.002、0.001。

      所以对于银行来说它的盈利应该是0.000 + 0.001 + 0.002 + 0.003 + 0.004 - 0.005 - 0.004 - 0.003 - 0.002 - 0.001 = -0.005。从结果中可以看出每10笔的利息银行可能就会损失0.005元,千万别小看这个数字,这对于银行来说就是一笔非常大的损失。面对这个问题就产生了如下的银行家涉入法了。该算法是由美国银行家提出了,主要用于修正采用上面四舍五入规则而产生的误差。如下:

      舍去位的数值小于5时,直接舍去。

      舍去位的数值大于5时,进位后舍去。

      当舍去位的数值等于5时,若5后面还有其他非0数值,则进位后舍去,若5后面是0时,则根据5前一位数的奇偶性来判断,奇数进位,偶数舍去。

      对于上面的规则我们举例说明

         11.556 = 11.56          ------六入

         11.554 = 11.55          -----四舍

         11.5551 = 11.56         -----五后有数进位

         11.545 = 11.54          -----五后无数,若前位为偶数应舍去

         11.555 = 11.56          -----五后无数,若前位为奇数应进位

      下面实例是使用银行家舍入法:

public static void main(String[] args) {
        BigDecimal d = new BigDecimal(100000);      //存款
        BigDecimal r = new BigDecimal(0.001875*3);   //利息
        BigDecimal i = d.multiply(r).setScale(2,RoundingMode.HALF_EVEN);     //使用银行家算法 
        
        System.out.println("季利息是:"+i);
        }
Output:
季利息是:562.50

 

 在上面简单地介绍了银行家舍入法,目前java支持7中舍入法:

      1、 ROUND_UP:远离零方向舍入。向绝对值最大的方向舍入,只要舍弃位非0即进位。

      2、 ROUND_DOWN:趋向零方向舍入。向绝对值最小的方向输入,所有的位都要舍弃,不存在进位情况。

     3、 ROUND_CEILING:向正无穷方向舍入。向正最大方向靠拢。若是正数,舍入行为类似于ROUND_UP,若为负数,舍入行为类似于ROUND_DOWN。Math.round()方法就是使用的此模式。

      4、 ROUND_FLOOR:向负无穷方向舍入。向负无穷方向靠拢。若是正数,舍入行为类似于ROUND_DOWN;若为负数,舍入行为类似于ROUND_UP。

      5、 HALF_UP:最近数字舍入(5进)。这是我们最经典的四舍五入。

      6、 HALF_DOWN:最近数字舍入(5舍)。在这里5是要舍弃的。

      7、 HAIL_EVEN:银行家舍入法。

 

      提到四舍五入那么保留位就必不可少了,在java运算中我们可以使用多种方式来实现保留位。

 

 

 

 

其实进位的数从1-9个数字。这些数字出现的机率是一样的。

正常的四舍五入。

1-4会被舍去。  1,2,3,4 一共4个数字。

5-9会被进位。5,6,7,8,9 一共5个数字。

正常的四舍五入会有4个数字舍去,5个数字会被进位。银行家的算法就是要更公平的进行取舍。

四舍六入五平分:

1,2,3,4 舍去。

6,7,8,9进位。

5 这个数看前面的数字决定。如果是偶数,则不进位。如果是奇数则进位。

 

四舍六入五平分例子:

  61.5   =62 。     小数点前面是1(奇数),则后面的0.5进位。结果是62。

  62.5  = 62 。     小数点前面是2(偶数),则后面的0.5不进位。结果是62。

 

 

 

 

 

 

 

 

 

 

 

在 Python 中,整数本身是没有小数部分的,因此严格来说,“对整数进行四舍五入”的概念并不常见。然而,如果用户希望基于某个逻辑对整数执行类似的处理,则可以通过特定的方式实现。 以下是几种可能的情况及其解决方案: --- ### **情况 1:通过 `round()` 函数** `round()` 是 Python 的内置函数,主要用于浮点数的四舍五入。虽然它通常用于带有小数的部分,但如果将整数视为具有隐含的小数位(例如 `7.0` 或者 `7.5`),则可以对其进行操作[^2]。 #### 示例代码: ```python number = 7.5 # 假设这是一个带小数的整数形式 rounded_number = round(number) # 使用 round 进行四舍五入 print(rounded_number) # 输出: 8 number_2 = 6.4 rounded_number_2 = round(number_2) print(rounded_number_2) # 输出: 6 ``` 需要注意的是,Python 3 的 `round()` 遵循“平分”规则,这意味着当数字正好位于中间值时(如 `.5`),会倾向于使结果更接近偶数[^3]。 --- ### **情况 2:模拟整数的四舍五入** 对于纯整数而言,无法直接应用四舍五入的概念。但是,如果希望通过某种方式扩展其含义,比如将其转化为浮点数后再处理,则可以借助以下方法: #### 示例代码: ```python def integer_round(n, decimal_place=0): factor = 10 ** decimal_place return int(round(n / factor) * factor) # 测试用例 result = integer_round(75, -1) # 将 75 转化为最近的十位倍数 (80) print(result) # 输出: 80 ``` 此方法允许指定一个基数位置来进行调整,从而间接实现了针对较大范围内的整数近似效果。 --- ### **情况 3:使用 NumPy 库** NumPy 提供了一个名为 `around()` 的功能强大的工具,能够高效地完成数组级别的运算以及单个数值的操作[^1]。 #### 示例代码: ```python import numpy as np value = np.array([7.5]) rounded_value = np.around(value).astype(int)[0] print(rounded_value) # 输出: 8 ``` 尽管这主要适用于批量数据处理场景,但对于单独实例同样有效。 --- ### **特殊情况下的取整需求** 有时开发者可能会遇到需要强制向上或向下取整的要求。此时可考虑引 `math` 模块中的两个专用函数——`ceil()` `floor()` 来分别满足这两种情形[^5]。 #### 示例代码: ```python import math num = 7.2 ceiling_result = math.ceil(num) # 向上取整 floored_result = math.floor(num) # 向下取整 print(f"Ceil of {num} is {ceiling_result}") # Ceil of 7.2 is 8 print(f"Floor of {num} is {floored_result}") # Floor of 7.2 is 7 ``` 以上这些技术手段共同构成了完整的解决框架,具体选用哪一种取决于实际应用场景个人偏好。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值