Java中BigDecimal类及8种舍入模式

本文详细介绍了Java中BigDecimal类的使用方法,包括如何处理高精度的数学运算,特别是在商业计算中。文章通过实例展示了如何使用BigDecimal进行除法运算并保留指定小数位数,同时解释了不同的舍入模式,如四舍五入、向下取整等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java在java.math包中提供的API类BigDecimal,用于对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象。
A.数字3333除以1000,保留3位小数点,四舍五入
import java.math.BigDecimal;

public class BigDecimalDemo {

	public static void main(String[] args) {
		double a = new BigDecimal(3333).divide(BigDecimal.valueOf(1000), 3, BigDecimal.ROUND_UP).doubleValue();
		System.out.println(a);
	}

}
//运行结果为3.333
BigDecimal提供了8种舍入方式
  1. ROUND_UP:舍入远离零的舍入模式。在丢弃非零部分之前始终增加数字(始终对非零舍弃部分前面的数字加1)。(注意,此舍入模式始终不会减少计算值的大小).
  2. ROUND_DOWN:接近零的舍入模式。在丢弃某部分之前始终不增加数字(从不对舍弃部分前面的数字加1,即截短)。(注意,此舍入模式始终不会增加计算值的大小).
  3. ROUND_CEILING:接近正无穷大的舍入模式。如果 BigDecimal 为正,则舍入行为与 ROUND_UP 相同;如果为负,则舍入行为与 ROUND_DOWN 相同。(注意,此舍入模式始终不会减少计算值).
  4. ROUND_FLOOR:接近负无穷大的舍入模式。如果 BigDecimal 为正,则舍入行为与 ROUND_DOWN 相同;如果为负,则舍入行为与 ROUND_UP 相同。(此舍入模式始终不会增加计算值).
  5. ROUND_HALF_UP:向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。
    如果舍弃部分 >= 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同(这是正常的的舍入模式(四舍五入)).
  6. ROUND_HALF_DOWN:向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为上舍入的舍入模式。如果舍弃部分 > 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同(五舍六入)。
  7. ROUND_HALF_EVEN:向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
    如果舍弃部分左边的数字为奇数,则舍入行为与 ROUND_HALF_UP 相同;如果为偶数,则舍入行为与 ROUND_HALF_DOWN 相同。
  8. ROUND_UNNECESSARY:断言请求的操作具有精确的结果,因此不需要舍入。如果对获得精确结果的操作指定此舍入模式,则抛出ArithmeticException。
题目: 链接:https://ac.nowcoder.com/acm/contest/318/D

远神最近对高精度感兴趣,给小萌新出了道简单的除法题,a除b保留n位小数。但是越老和翔神觉得太简单了,就多加了两种操作。
翔化,结果向下取整。
越化,结果最后一位四舍五入。

输入描述:
多组输入。
第一行输入三个数a,b,n( 1≤a≤100000 ,1≤b≤100000,0≤n≤1000)。
第二行一个字符串Xiang,Yue表示翔化和越化。
输出描述
输出翔化或者越化的结果。
示例1
输入
2 3 5
Xiang
2 3 5
Yue
输出
0.66666
0.66667
AC–Code
import java.math.*;
import java.util.*;
import java.util.*;
public class Main {
    public static void main(String[] args) {
        int t;
        Scanner cin=new Scanner (System.in);
        while(cin.hasNext())
        {
            BigDecimal a,b;
            int c;
            String s;
            a=cin.nextBigDecimal();
            b=cin.nextBigDecimal();
            c=cin.nextInt();
            s=cin.next();
            if(s.compareTo("Xiang")==0)
            {
                System.out.println(a.divide(b,c,BigDecimal.ROUND_FLOOR));
            }
            else
                System.out.println(a.divide(b,c,BigDecimal.ROUND_HALF_UP));
        }
    }
}
### JavaBigDecimal舍入模式 #### ROUND_UP 模式 当使用 `BigDecimal.ROUND_UP` 时,任何非零的小数部分都会被向上舍入。此操作不会考虑符号。 ```java BigDecimal bd = new BigDecimal("36").divide(BigDecimal.valueOf(1000), 2, BigDecimal.ROUND_UP); System.out.println(bd.doubleValue()); ``` 这段代码的结果会是 `0.04`[^2]。 #### ROUND_DOWN 模式 采用 `BigDecimal.ROUND_DOWN` 方式,则直接丢弃多余的部分而不做任何处理,即总是向零方向取整。 ```java BigDecimal num = new BigDecimal("7.89"); num = num.setScale(1, BigDecimal.ROUND_DOWN); // 输出结果为 7.8 ``` #### ROUND_CEILING 模式 对于正数而言,`BigDecimal.ROUND_CEILING` 行为似于 `ROUND_UP`; 对于负数来说则像 `ROUND_DOWN`. ```java BigDecimal positiveNum = new BigDecimal("5.567"); positiveNum = positiveNum.setScale(2, BigDecimal.ROUND_CEILING); // 正数情况下输出 5.57 BigDecimal negativeNum = new BigDecimal("-5.567"); negativeNum = negativeNum.setScale(2, BigDecimal.ROUND_CEILING); // 负数情况下输出 -5.56 ``` #### ROUND_FLOOR 模式 与 `ROUND_CEILING` 相反,在正值条件下表现得如同 `ROUND_DOWN`,而在负值下则是 `ROUND_UP`. ```java BigDecimal posFloor = new BigDecimal("4.456"); posFloor = posFloor.setScale(2, BigDecimal.ROUND_FLOOR); // 输出 4.45 BigDecimal negFloor = new BigDecimal("-4.456"); negFloor = negFloor.setScale(2, BigDecimal.ROUND_FLOOR); // 输出 -4.46 ``` #### HALF_UP 模式 这是最常用的舍入方式之一,遵循四舍五入原则,但是遇到 .5 这样的情况时总会朝远离零的方向舍入。 ```java BigDecimal halfUpExample = new BigDecimal("2.5"); halfUpExample = halfUpExample.setScale(0, BigDecimal.ROUND_HALF_UP); // 输出 3 ``` #### HALF_DOWN 模式 同样基于四舍五入的原则,不过在面对 `.5` 时会选择更接近于零的一方进行舍入。 ```java BigDecimal halfDownExample = new BigDecimal("2.5"); halfDownExample = halfDownExample.setScale(0, BigDecimal.ROUND_HALF_DOWN); // 输出 2 ``` #### HALF_EVEN (银行家算法) 这种舍入策略也被称为“银行家舍入”,它会在偶数和奇数之间交替选择最近的一个数值作为最终结果;如果两个距离相等,则优先选取偶数。 ```java BigDecimal bankerRoundingEven = new BigDecimal("2.5"); bankerRoundingEven = bankerRoundingEven.setScale(0, BigDecimal.ROUND_HALF_EVEN); // 输出 2 BigDecimal bankerRoundingOdd = new BigDecimal("3.5"); bankerRoundingOdd = bankerRoundingOdd.setScale(0, BigDecimal.ROUND_HALF_EVEN); // 输出 4 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值