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种舍入方式
- ROUND_UP:舍入远离零的舍入模式。在丢弃非零部分之前始终增加数字(始终对非零舍弃部分前面的数字加1)。(注意,此舍入模式始终不会减少计算值的大小).
- ROUND_DOWN:接近零的舍入模式。在丢弃某部分之前始终不增加数字(从不对舍弃部分前面的数字加1,即截短)。(注意,此舍入模式始终不会增加计算值的大小).
- ROUND_CEILING:接近正无穷大的舍入模式。如果 BigDecimal 为正,则舍入行为与 ROUND_UP 相同;如果为负,则舍入行为与 ROUND_DOWN 相同。(注意,此舍入模式始终不会减少计算值).
- ROUND_FLOOR:接近负无穷大的舍入模式。如果 BigDecimal 为正,则舍入行为与 ROUND_DOWN 相同;如果为负,则舍入行为与 ROUND_UP 相同。(此舍入模式始终不会增加计算值).
- ROUND_HALF_UP:向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。
如果舍弃部分 >= 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同(这是正常的的舍入模式(四舍五入)). - ROUND_HALF_DOWN:向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为上舍入的舍入模式。如果舍弃部分 > 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同(五舍六入)。
- ROUND_HALF_EVEN:向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
如果舍弃部分左边的数字为奇数,则舍入行为与 ROUND_HALF_UP 相同;如果为偶数,则舍入行为与 ROUND_HALF_DOWN 相同。 - 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));
}
}
}